React教程:父子组件传值(组件通信)

墨蓝 2023-07-08 12:27 83阅读 0赞

1、父组件传值子组件

在引用子组件的时候传递,相当于一个属性,例如:在子组件内通过porps.param获取到这个param的值。

父组件向子组件传值,通过props,将父组件的state传递给了子组件。

父组件代码片段:

  1. constructor(props){
  2. super(props)
  3. this.state={
  4. message:"i am from parent"
  5. }
  6. }
  7. render(){
  8. return(
  9. <Child txt={this.state.message}/>
  10. )
  11. }
  12. }

子组件代码片段:

  1. render(){
  2. return(
  3. <p>{this.props.txt}</p>
  4. )
  5. }

完整示例

创建父组件 index.js

  1. import React from 'react';
  2. import ReactDOM from 'react-dom';
  3. import User from './User';//引入子组件
  4. //定义数据
  5. const person = {
  6. name: 'Tom',
  7. age:20
  8. }
  9. ReactDOM.render(
  10. //渲染子组件,并向子组件传递name,age属性
  11. <User name={person.name} age={person.age}></User>
  12. , document.getElementById('root'));

创建子组件 User.js

  1. import React from 'react';
  2. class User extends React.Component{
  3. render(){
  4. return (
  5. // 使用props属性接收父组件传递过来的参数
  6. <div>{this.props.name},{this.props.age}</div>
  7. );
  8. }
  9. }
  10. export default User;

在父组件中可以使用展开运算符 ... 传递对象

index.js文件

  1. ReactDOM.render(
  2. //渲染子组件,并向子组件传递name,age属性
  3. <User {...person}></User>
  4. , document.getElementById('root'));

User.js文件

  1. render(){
  2. return (
  3. // 使用props属性接收父组件传递过来的参数
  4. <div>{this.props.name},{this.props.age}</div>
  5. );
  6. }

2、子组件传值父组件

子组件通过调用父组件传递到子组件的方法向父组件传递消息的。

完整案例

子组件 Son.js 文件代码示例:

  1. import React from 'react';
  2. class Son extends React.Component {
  3. //构造方法
  4. constructor(){
  5. super();
  6. this.state = {
  7. inputValue:''
  8. }
  9. }
  10. //按钮点击事件
  11. handleClick(){
  12. //通过props属性获取父组件的getdata方法,并将this.state值传递过去
  13. this.props.getdata(this.state.inputValue);
  14. }
  15. //输入框事件,用于为this.state赋值
  16. handleChange(e){
  17. this.setState({
  18. inputValue: e.target.value
  19. });
  20. }
  21. render(){
  22. return (
  23. <React.Fragment>
  24. <input onChange={this.handleChange.bind(this)}></input>
  25. <button onClick={this.handleClick.bind(this)}>点击获取数据</button>
  26. </React.Fragment>
  27. );
  28. }
  29. }
  30. export default Son;

父组件 Parent.js 文件代码示例:

  1. import React from 'react';
  2. import Son from './Son';
  3. class Parent extends React.Component {
  4. //构造方法
  5. constructor(){
  6. super();
  7. this.state = {
  8. mess: '' //初始化mess属性
  9. }
  10. }
  11. //用于接收子组件的传值方法,参数为子组件传递过来的值
  12. getDatas(msg){
  13. //把子组件传递过来的值赋给this.state中的属性
  14. this.setState({
  15. mess: msg
  16. });
  17. }
  18. render(){
  19. return (
  20. <React.Fragment>
  21. {/* 渲染子组件,设置子组件访问的方法,
  22. getdata属性名为子组件中调用的父组件方法名 */}
  23. <Son getdata={this.getDatas.bind(this)}></Son>
  24. <div>展示数据:{this.state.mess}</div>
  25. </React.Fragment>
  26. );
  27. }
  28. }
  29. export default Parent;

入口文件 index.js示例代码:

  1. import React from 'react';
  2. import ReactDOM from 'react-dom';
  3. import Parent from './Parent';
  4. ReactDOM.render(<Parent></Parent>, document.getElementById('root'));

3、兄弟组件传值

兄弟组件之间的传值,是通过父组件做的中转 ,流程为:

组件A -- 传值 --> 父组件 -- 传值 --> 组件B

代码示例:

创建 Acls.js 组件,用于提供数据

  1. import React from 'react';
  2. class Acls extends React.Component {
  3. //按钮点击事件,向父组件Pcls.js传值
  4. handleClick(){
  5. this.props.data("hello...React...");
  6. }
  7. render(){
  8. return (
  9. <button onClick={this.handleClick.bind(this)}>Acls组件中获取数据</button>
  10. );
  11. }
  12. }
  13. export default Acls;

创建父组件 Pcls.js 用于中转数据

  1. import React from 'react';
  2. import Acls from './Acls';
  3. import Bcls from './Bcls';
  4. class Pcls extends React.Component {
  5. //构造函数
  6. constructor(){
  7. super();
  8. this.state = {
  9. mess: ''
  10. }
  11. }
  12. //向子组件Acls.js提供的传值方法,参数为获取的子组件传过来的值
  13. getDatas(data){
  14. this.setState({
  15. mess: data
  16. });
  17. }
  18. render(){
  19. return (
  20. <React.Fragment>
  21. Pcls组件中显示按钮并传值:
  22. <Acls data={this.getDatas.bind(this)}></Acls>
  23. <Bcls mess={this.state.mess}></Bcls>
  24. </React.Fragment>
  25. );
  26. }
  27. }
  28. export default Pcls;

创建子组件 Bcls.js 用于展示从 Acls.js 组件中生成的数据

  1. import React from 'react';
  2. class Bcls extends React.Component {
  3. render(){
  4. return (
  5. <div>Bcls组件中展示数据:{this.props.mess}</div>
  6. );
  7. }
  8. }
  9. export default Bcls;

发表评论

表情:
评论列表 (有 0 条评论,83人围观)

还没有评论,来说两句吧...

相关阅读