传递给组件

简介: 传递给组件

React 组件使用 props 相互通信。每个父组件都可以通过为其子组件提供道具来将一些信息传递给子组件。Props 可能会让您想起 HTML 属性,但您可以通过它们传递任何 JavaScript 值,包括对象、数组和函数。

Props 是传递给 JSX 标签的信息。例如,、、、、和是您可以传递给 :classNamesrcaltwidthheight<img>

function Avatar() {
  return (
    <img
      className="avatar"
      src="https://i.imgur.com/1bX5QH6.jpg"
      alt="Lin Lanying"
      width={100}
      height={100}
    />
  );
}
 
export default function Profile() {
  return (
    <Avatar />
  );
}

可以传递给标签的 prop 是预定义的(ReactDOM 符合 HTML 标准)。但是你可以将任何道具传递给自己组件,比如 ,来自定义它们。就是这样!<img><Avatar>

将道具传递给组件

在此代码中,组件不会将任何 props 传递给其子组件:ProfileAvatar

export default function Profile() {
  return (
    <Avatar />
  );
}

你可以分两步给出一些道具。Avatar

第 1 步:将 props 传递给子组件

首先,将一些道具传递给 .例如,让我们传递两个道具:(一个对象)和(一个数字):Avatarpersonsize

export default function Profile() {
  return (
    <Avatar
      person={{ name: 'Lin Lanying', imageId: '1bX5QH6' }}
      size={100}
    />
  );
}

第 2 步:读取子组件内的 props

您可以通过列出它们的名称来阅读这些道具,这些道具在内部和后面用逗号分隔。这使您可以在代码中使用它们,就像使用变量一样。person, size({})function AvatarAvatar

function Avatar({ person, size }) {
  // person and size are available here
}

添加一些逻辑,使用 和 props 进行渲染,就完成了。Avatarpersonsize

现在,您可以配置为使用不同的道具以多种不同的方式进行渲染。尝试调整值!Avatar

import { getImageUrl } from './utils.js';
 
function Avatar({ person, size }) {
  return (
    <img
      className="avatar"
      src={getImageUrl(person)}
      alt={person.name}
      width={size}
      height={size}
    />
  );
}
 
export default function Profile() {
  return (
    <div>
      <Avatar
        size={100}
        person={{ 
          name: 'Katsuko Saruhashi', 
          imageId: 'YfeOqp2'
        }}
      />
      <Avatar
        size={80}
        person={{
          name: 'Aklilu Lemma', 
          imageId: 'OKS67lh'
        }}
      />
      <Avatar
        size={50}
        person={{ 
          name: 'Lin Lanying',
          imageId: '1bX5QH6'
        }}
      />
    </div>
  );
}
export function getImageUrl(person, size = 's') {
  return (
    'https://i.imgur.com/' +
    person.imageId +
    size +
    '.jpg'
  );
}


相关文章
|
20天前
|
JavaScript
子组件向父组件传参的方式?
子组件向父组件传参的方式?
10 0
|
1月前
|
前端开发 JavaScript 开发者
vue3、react组件数据传值对比分析——父组件传递子组件,子组件传递父组件(二)
vue3、react组件数据传值对比分析——父组件传递子组件,子组件传递父组件
31 0
|
1月前
|
JavaScript 前端开发 算法
vue3、react组件数据传值对比分析——父组件传递子组件,子组件传递父组件(一)
vue3、react组件数据传值对比分析——父组件传递子组件,子组件传递父组件
31 0
|
1月前
|
小程序
子组件调用父组件的方法并传递数据
子组件调用父组件的方法并传递数据
|
8月前
|
人工智能 自然语言处理 JavaScript
vue 父组件将异步请求回来的数据传递给子组件,子组件props可以接收到,但是没有值
vue 父组件将异步请求回来的数据传递给子组件,子组件props可以接收到,但是没有值
36 0
|
9月前
|
JavaScript 前端开发 C++
04、props接收父组件的数据
04、props接收父组件的数据
|
11月前
需求:组件A可以直接调用组件B的方法
1.封装的方法: ZJeventCenter.js
|
JavaScript
vue中父组件异步数据通过props方式传递给子组件,子组件接收不到的问题
vue中父组件异步数据通过props方式传递给子组件,子组件接收不到的问题
321 0
|
API C#
我不想再传递 nameof 了
有的时候抛出一个异常,我们需要知道是哪个方法抛出的异常。那么,我们可以通过传递 nameof 来获取调用者的方法名。但是,感觉很烦,每次都要传递 nameof。那么,有没有更好的方法呢?
68 0
我不想再传递 nameof 了
vue3 子组件接收父组件的值(defineProps )
vue3 子组件接收父组件的值(defineProps )
700 0