vue中不同情况下的通讯方式

本文详细介绍了Vue中组件间通信的各种方法,包括Vuex、provide/inject、props/$emit、eventBus、$attrs/$listeners。在同浏览器同页签内,重点讲解了这些方法的适用场景和注意事项。对于不同浏览器页签间的通信,提到了监听storage事件的方式。
摘要由CSDN通过智能技术生成

前情提要

其实对于vue中组件通讯这件事大家也都不陌生。甚至张口就来,毕竟这也是面试中的经常会问到的。由于之前没有进行过细致的考虑,在写小项目的时候遇到了组件中通讯的需求,然后上来就写,结果发现没有用,查了好久才知道那种方式不适用这样情况。所以经过这次事情决定写篇文章,对于通讯方式进行更清楚更细致的分类,毕竟不是每种通讯方式都适用于所有场景。

同窗口(也就是同浏览器同一个页签内)

同浏览器同页签内主要涉及的就是父子组件的传值,或者同宗不用源的组件传值。

vuex:状态管理器:适用一个项目里的任何组件,包容性极强

对于状态管理器的概念大家应该也不会陌生。

  • 多个组件可以共享一个或者多个状态值。不管组件的层级有多深都可以正常访问。所以这是一种官方直接支持的通讯方式。
  • 注意:对于小型单页应用而言,该选择并不是很建议,对于小型项目而言使用vuex反而会变得更加繁琐,就像是一个75斤150cm的人,穿了一件170cm110斤人的衣服一样,看着就很松松垮垮撑不起来。
provide / inject (写法基于v2.2.1及以上版本):适用N级组件,但是必须是单线传承的那种

这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在其上下游关系成立的时间里始终生效。

  • 就是相当于有一个N层楼的楼房,最顶层的是父级组件,每层楼之间会公用一个管子,这个管子就是provide。而管子在每层楼都有一个出口叫:inject
  • 注意:provideinject 绑定并不是可响应的。不过如果你传入了一个可监听的对象,那么其对象的 property 还是可响应的。
  • 让咱们来看看代码
// parent.vue
// 此处忽略template模板的东西
<script>
export default {
    name: 'parent',
    // provide有两种写法
    // 第一种
    provide: {
        a: 1,
        b: 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值