Vue组件间通信

  1. props、emit(最常用的父子通讯方式) 

父组件传入属性,子组件通过props接收,就可以在内部this.xxx的方式使用

子组件传给父组件通过$emit(时间名,传递的参数)向外弹出一个自定义事件,在父组件种监听子组件的自定义事件,同时也能获取子组件传出来的参数

vm.$on(event,fn):监听event事件后运行fn

vm.$off(event):移除自定义事件监听器

       2. 事件总线 EventBus(常用任意两个组件之间的通讯)

原理:注册的事件存起来,等触发事件时再调用。定义一个类去处理事件,并挂载到Vue实例的this上即可注册和触发事件,也可拓展一些事件管理

       3. Vuex状态管理(vue的核心插件,用于任意组件的任意通讯,需要注意刷新后有可能vuex数据会丢失)

创建全局唯一的状态管理仓库store,有同步mutations,异步actions的方式去管理数据,有缓存数据getters,还能分成各个模块modules易于维护

       4. ref/$refs(父子组件之间的通信)

ref: 这个属性用在子组件上,它的作用就是指向子组件的实例,可以通过实例来访问组件的数据和方法。

       5. 依赖注入(provide/inject)

vue中依赖注入,该方法用于父子组件之间 的通信。当然这里所说的父子不一定是真正的父子,也可以是祖孙组件,在层数很深的情况下,可以使用这种方式来进行传值。就不用一层一层的传递数据了。

provide和inject是vue提供的两个钩子,和data、methods是同级的。并且provide的书写形式跟data一样。

provide钩子是用来发送数据或者方法;inject钩子用来接收数据或方法

       6. $parent/$children

使用$parent可以让组件访问父组件的实例(访问的是上一级父组件的属性和方法)

使用$children可以让组件访问子组件的实例,但是,$children并不能保证顺寻,并且访问的数据也不是响应式的。

通过$parent访问到的是上一级父组件的实例,可以使用$root来访问根组件的实例。

在组件中使用$children拿到的是所有的子组件的实例,他是一个数组,并且是无序的。

在根组件#app上拿$parent得到的是new Vue()的实例,在这实例上在拿$parent得到的是undefined,而在最底层的子组件拿$children是个空数组

$children的值是数组,而$parent是个对象。

      7. $attrs/$listeners

考虑一种场景,如果A是B组件的父组件,B是C组件的父组件。如果想要A给C组件传递数据,这种隔代传数据的情况该使用哪种方式呢?

如果是用props/$emit来一级一级的传递,确实可以完成,但是比较复杂,如果使用事件总线,在多人开发或者项目较大的时候,维护起来很麻烦,如果使用vuex,如果仅仅是传递数据,那可能有点浪费了。

针对上述情况,vue引入了$$attrs/$listeners 实现组件之间的跨代通信

$attrs:继承所有的父组件属性(除了props传递的属性、class和style),已办用在子组件的子元素上

$$listeners:该属性是一个对象,里面包含了作用在这个组件上的所有监听器,可以配合v-on="$listeners"将所有的事件监听器指向这个组件的某个特定的子元素。(相当于子组件继承父组件的事件)

      8. slot插槽

父子通信 插槽主要作用是传递结构,可以直接让子组件不用书写自己的结构,在element-ui中使用的频率非常高

具名插槽:需要书写name;

作用域插槽:子组件的数据来源于父组件,但是子组件的自己的结构有父亲决定。

     9. v-model 实现组件通信

v-model:指令,可以手机表单数据[text, radio, checkbox, range]等等;v-model手机checkbox需要用数组收集

v-model:实现原理 :value @input  (就是利用的props传值和$emit自定义事件触发父组件事件和向父组件传递数据来实现组件间通信) 

    10. 属性修饰符.sync 

可以实现父子数据同步。

个人理解就是v-model简写


<h2>不使用sync修改符</h2>
    <!-- 给子组件绑定一个自定义事件:update:money -->
<Child :money="money"  @update:money="handler"></Child>
<h2>使用sync修改符</h2>
<Child :money.sync="money"></Child>
//前面两者所代表的含义是一样的,都是给子组件传递了一个money数据,然后还给子组件传递了自定义事件update:money
//子组件
<span>小明每次花100元</span>
<button @click="$emit('update:money',money-100)">花钱</button>

     11. localStorage/sessionStorage

直接将数据存储在本地浏览器上,使用的时候直接调用本地数据就行.

localStorage只支持string类型的存储

存:JSON.stringify(转换字符串)

取:JSON.parse

     12. inheritAttrs

组件传值一般是通过props传值的。inheritAttrs默认值为true,true的意思是将父组件中除了props外的属性添加到子组件的根节点上(说明即使设置为true,子组件仍然可以通过$attr获取到props意外的属性)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值