react+ts父子组件传值

父传子

①在父组件中定义const nameFromParent: string = "John";

②从父组件传递给子组件<ChildComponent name={nameFromParent} />

③在子组件中定义属性的类型interface ChildProps { age: number;}

④如果数据多需要解构再使用const { name,... } = props;,如果只有一个参数也可以直接写在函数的参数括号中

⑤在子组件中使用<p>Name: {name}</p>

import React from 'react';

// 子组件
interface ChildProps {
  name: string;
  age: number;
  handleClick: () => void;
}

const ChildComponent: React.FC<ChildProps> = (...props) => {
  const { name, age, handleClick } = props;

  return (
    <div>
      <p>Child Component</p>
      <p>Name: {name}</p>
      <p>Age: {age}</p>
      <button onClick={handleClick}>Click me</button>
    </div>
  );
};

// 父组件
const ParentComponent: React.FC<ParentProps> = () => {
  const nameFromParent: string = "John";
  const ageFromParent: number = 25;

  const handleClick = () => {
    console.log('Button clicked!');
  };

  // 使用 {...props} 将所有属性传递给子组件
  return (
    <div>
      <p>Parent Component</p>
      <ChildComponent name={nameFromParent} age={ageFromParent} handleClick={handleClick} />
    </div>
  );
};

export default ParentComponent;

子传父

①在父组件中定义事件名称并赋予点击事件<ChildComponent sendDataToParent={handleDataFromChild} />

②在父组件中实现点击事件const handleDataFromChild = (data: string) => {};

③在子组件中定义事件类型interface ChildProps {sendDataToParent: (data: string) => void;}

④如果数据多需要解构再使用const { sendDataToParent,... } = props;,如果只有一个参数也可以直接卸载函数的参数括号中

⑤在子组件中定义点击事件并<button onClick={sendData}>Send Data to Parent</button>

⑥并在子组件中实现点击事件调通过父组件传过来的事件传递参数const sendData = () => {sendDataToParent(data); };

另外如果想不点击直接发送参数的话可以在useEffect(() => {sendDataToParent(data);},[sendDataToParent])

import React from 'react';

// 子组件
interface ChildProps {
  sendDataToParent: (data: string) => void;
}

const ChildComponent: React.FC<ChildProps> = ({ sendDataToParent }) => {
  const sendData = () => {
    const data = "Data from Child";
    // 在需要的时候调用回调函数传递信息给父组件
    sendDataToParent(data);
  };

  return (
    <div>
      <p>Child Component</p>
      <button onClick={sendData}>Send Data to Parent</button>
    </div>
  );
};


// 父组件
const ParentComponent: React.FC<ParentProps> = () => {
    
  const handleDataFromChild = (data: string) => {
    console.log('Data received from Child:', data);
    // 在这里处理从子组件接收到的数据
  };

  return (
    <div>
      <p>Parent Component</p>
      {/* 将回调函数传递给子组件 */}
      <ChildComponent sendDataToParent={handleDataFromChild} />
    </div>
  );
};

export default ParentComponent;

  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
React中,父组件向子组件传值可以通过props来实现。父组件可以将需要传递的数据作为属性传递给子组件,子组件通过props来接收这些数据。下面是几种常见的父子组件传值的方式: 1. 父组件通过props传递数据给子组件: 父组件定义一个属性,并将需要传递的数据作为该属性的值,然后将子组件引入到父组件中,并将该属性作为子组件的一个属性传递进去。子组件可以通过props来接收并使用这个数据。例如,父组件中定义属性`txt0`,并将它传递给子组件`Child`: ```javascript <Child txt={this.state.txt0} /> ``` 子组件可以通过props来接收并使用父组件传递的数据: ```javascript this.props.txt ``` 2. 父组件通过回调函数传递数据给子组件: 父组件定义一个回调函数,并将该函数作为属性传递给子组件。子组件可以通过调用这个回调函数,将需要传递的数据作为参数传递给父组件。例如,父组件中定义一个回调函数`getDatas`: ```javascript getDatas(msg){ this.setState({ mess: msg }); } ``` 然后将该函数作为属性传递给子组件`Son`: ```javascript <Son getdata={this.getDatas.bind(this)}></Son> ``` 子组件可以通过调用父组件传递的回调函数,并将需要传递的数据作为参数传递给它: ```javascript this.props.getdata(data); ``` 3. 父组件通过context传递数据给子组件: Context是React提供的一种跨组件传递数据的机制。父组件可以通过定义一个Context,并将需要传递的数据放在Context中,然后子组件可以通过访问Context来获取这些数据。具体的实现可以参考React官方文档中关于Context的介绍。 以上是React父子组件传值的几种常见方式,你可以根据具体的需求选择合适的方式来实现父子组件之间的数据传递。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [React父子组件间的传值的方法](https://download.csdn.net/download/weixin_38595850/13633672)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [React教程:父子组件传值(组件通信)](https://blog.csdn.net/p445098355/article/details/104519363)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [React父子组件传值](https://blog.csdn.net/weixin_45817109/article/details/103628428)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

又又爱拍照

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值