vue组件之间的传值
admin
2023-02-16 13:40:06
0

这篇文章主要介绍了父组件传值子组件、子组件传值父组件、兄弟组件传值三种传值方式,需要的朋友可以参考下。以下是组件传值的使用示范。

1、父组件传值子组件

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

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

父组件代码片段:

constructor(props){
    super(props)
    this.state={
      message:"i am from parent"
    }
  }
  render(){
    return(
          
    )
  }
}

子组件代码片段:

render(){
    return(
          

{this.props.txt}

   ) }

完整示例

创建父组件 index.js

import React from 'react';
import ReactDOM from 'react-dom';
import User from './User';//引入子组件

//定义数据
const person = {
    name: 'Tom',
    age:20
}

ReactDOM.render(
    //渲染子组件,并向子组件传递name,age属性
    
    , document.getElementById('root'));

创建子组件 User.js

import React from 'react';

class User extends React.Component{
    render(){
        return (
            // 使用props属性接收父组件传递过来的参数
            
{this.props.name},{this.props.age}
       );    } } export default User;

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

index.js文件

ReactDOM.render(
    //渲染子组件,并向子组件传递name,age属性
    
    , document.getElementById('root'));

User.js文件

render(){
   return (
       // 使用props属性接收父组件传递过来的参数
       
{this.props.name},{this.props.age}
  ); }

2、子组件传值父组件

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

完整案例

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

import React from 'react';

class Son extends React.Component {
    //构造方法
    constructor(){
        super();
        this.state = {
            inputValue:''
        }
    }
    //按钮点击事件
    handleClick(){
        //通过props属性获取父组件的getdata方法,并将this.state值传递过去
        this.props.getdata(this.state.inputValue);
    }
    //输入框事件,用于为this.state赋值
    handleChange(e){
        this.setState({
            inputValue: e.target.value
        });
    }

    render(){
        return (
            
                
                
            
        );
    }

}

export default Son;

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

import React from 'react';
import Son from './Son';

class Parent extends React.Component {
    //构造方法
    constructor(){
        super();
        this.state = {
            mess: '' //初始化mess属性
        }
    }
    //用于接收子组件的传值方法,参数为子组件传递过来的值
    getDatas(msg){
        //把子组件传递过来的值赋给this.state中的属性
        this.setState({
            mess: msg
        });
    }

    render(){
        return (
            
                {/* 渲染子组件,设置子组件访问的方法,
                getdata属性名为子组件中调用的父组件方法名 */}
                
                
展示数据:{this.state.mess}
           
       );    } } export default Parent;

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

import React from 'react';
import ReactDOM from 'react-dom';
import Parent from './Parent';

ReactDOM.render(, document.getElementById('root'));

3、兄弟组件传值

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

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

代码示例:

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

import React from 'react';

class Acls extends React.Component {
    //按钮点击事件,向父组件Pcls.js传值
    handleClick(){
        this.props.data("hello...React...");
    }

    render(){
        return (
            
        );
    }
}

export default Acls;

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

import React from 'react';
import Acls from './Acls';
import Bcls from './Bcls';

class Pcls extends React.Component {
    //构造函数
    constructor(){
        super();
        this.state = {
            mess: ''
        }
    }
    //向子组件Acls.js提供的传值方法,参数为获取的子组件传过来的值
    getDatas(data){
        this.setState({
            mess: data
        });
    }

    render(){
        return (
            
                Pcls组件中显示按钮并传值:
                
                
            
        );
    }
}

export default Pcls;

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


import React from 'react';class Bcls extends React.Component {

    render(){
        return (
            
在Bcls组件中展示数据:{this.props.mess}
       );    } } export default Bcls;

看完父组件传值子组件、子组件传值父组件、兄弟组件传值三种传值方式的使用案例,你们学会这三种组件传值方法了吗,如果想了解更多相关内容,欢迎关注行业资讯。

相关内容

热门资讯

人民日报:中国棋坛唯一的“棋圣... “棋圣”聂卫平离去人生棋局不止于擂台本报记者 郑 轶《人民日报》(2026年01月16日 第 15 ...
惠充天下获数百万元天使轮融资 来源:滇云发现 近日,惠充智联(湖南)控股有限公司(品牌简称“惠充天下”)宣布完成数百万元天使轮融资...
人民日报谈如何降低生娃养娃成本... 如何降低生娃养娃成本(读者点题·共同关注)本报记者 申少铁《人民日报》(2026年01月16日 第 ...
抖音申请信息处理专利以提升模型... 国家知识产权局信息显示,脸萌有限公司和抖音视界有限公司申请一项名为“一种信息处理的方法、装置、设备和...
千问会是阿里的豆包时刻吗? 文 | 市象,作者 | 王浩然 古廿,编辑 | 古廿 “如果这场发布会没有人就完美了”有互联网人士...
广货行天下 | 国内外游客纷至... “我这几年都会专程来深圳买手机,不仅方便,门店规模大、机型全,还能叠加国补和消费优惠。”1月14日,...
苏博泰克申请具备超压泄放功能的... 国家知识产权局信息显示,苏博泰克(苏州)科学仪器有限公司申请一项名为“一种具备超压泄放功能的高压阀门...
美媒:盗墓之风正席卷美国 据《华尔街日报》1月14日报道,由于用于工业、建筑和家居装饰的废金属需求不断增长,一场亵渎死者的盗墓...
苏州斯特智能申请导向机构及压机... 国家知识产权局信息显示,苏州斯特智能科技有限公司申请一项名为“导向机构及压机”的专利,公开号CN12...
首个能源大模型发布 远景与中东... 1月13日,2026年阿布扎比可持续发展周(ADSW)远景全球科技日活动上,远景科技集团与阿联酋未来...