Vue.js---组件间传递数据的方法(初级)

父组件向子组件传数据:

        这种情况比较常见,也相对比较简单,只需要利用 props 配置项在编写组件标签时传递数据即可、注意需要加上 : 进行数据绑定。

父组件:
<MyList :todos="todos"/>

子组件:
export default {
    name:'MyList',
    components:{
        MyItem
    },
    props:['todos']
}

子组件向父组件传数据:

        这种情况同样通过 props 配置项进行传递,但传递的不是数据本身。props 配置项除了可以传递 data 外,还可以传递 methods 。所以我们可以在父组件编写一个方法传递到子组件,这个方法需要传递参数,再在子组件调用此方法时传入需要传递的数据作为参数。通过控制台输出可以发现在子组件调用该方法时,this 的指向仍为父组件,所以我们就可以通过 this 将参数中的数据存储在父组件中。

父组件:
receive(x){
    console.log(this);
    console.log(x);
    this.todos.unshift(x);
}
//此处不要加括号!
<MyHeader :receive="receive"/>

子组件:
methods:{
    add(e){
        this.receive(todoobj);
    }
},
props:['receive']

兄弟组件之间传数据:

        这种情况可以理解为以上两种情况的叠加。首先将需要传递的数据从当前组件移动到两组件共同的父组件中,然后进行上述两步操作即可,不再赘述。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值