vue组件通信的方式

1.父传子 props

        在父组件自定义属性名传递数据,在父组件在引入和挂载子组件,在父组件使用它,

        在标签上绑定你想传入的数据,在子组件上用props接受数据,并且使用它

2.子传父 $emit

        父组件向子组件传递事件方法,子组件通过$emit触发事件,回调给父组件

3.兄弟传值 eventbus

        在父组件设置 let bus = new vue()   

        在子组件中如果要 发送数据用 bus.$emit('')        接收数据用bus.$on('')

4.provide/inject

    provide/inject 主要解决了跨级组件间的通信,他的使用场景主要是子组件获取上级组件的状态,跨级组件间建立了一种主动提供与依赖注入的关系,但是provide和inject的绑定不是可响应的

5.$parent / $children与 ref

    $parent :如果当前实例有的话,访问父组件

   $children:当前实例的直接子组件。需要注意 $children并不保证顺序,也不是响应式的。如果你发现自己正在尝试使用 $children来进行数据绑定,考虑使用一个数组配合 v-for 来生成子组件,并且使用 Array 作为真正的来源。

   ref:如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;

                    如果用在子组件上,引用就指向组件实例

   $parent / $children:访问父 / 子实例

                这两种都是直接得到组件实例,使用后可以直接调用组件的方法或访问数据,

                不过无法在跨级或兄弟间通信

6.vuex

        vuex 就是一个仓库,仓库里放了很多对象。在state中存放数据源,当组件要更改state中的数据时,必须通过mutation进行,mutation储存的是改变state中数据的操作方法,之后通过actions储存的操作去触发mutation中的方法,由组件中的$store.dispatch('action 名称', data1)来触发。然后由commit()来触发mutation的调用 , 间接更新 state。


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值