超详细vue2中组件之间传值方式

Vue中通信方式

1-props / $emit

父组件向子组件传值
父组件通过props的方式向子组件传递数据,而通过$emit 子组件可以向父组件通信
下面通过一个例子说明父组件如何向子组件传递数据:在子组件article.vue中如何获取父组件section.vue中的数据articles:[‘红楼梦’, ‘西游记’,‘三国演义’]
在这里插入图片描述

总结: prop 只可以从上一级组件传递到下一级组件(父子组件),即所谓的单向数据流。而且 prop 只读,不可被修改,所有修改都会失效并警告
子组件向父组件传值
对于$emit 我自己的理解是这样的: $emit绑定一个自定义事件, 当这个语句被执行时, 就会将参数arg传递给父组件,父组件通过v-on监听并接收参数。 通过一个例子,说明子组件如何向父组件传递数据。
在上个例子的基础上, 点击页面渲染出来的ariticle的item, 父组件中显示在数组中的下标
在这里插入图片描述

2-$children / $parent

在这里插入图片描述
上面这张图片是vue官方的解释,通过 p a r e n t 和 parent和 parentchildren就可以访问组件的实例,拿到实例代表什么?代表可以访问此组件的所有方法和data。接下来就是怎么实现拿到指定组件的实例。
使用方法
在这里插入图片描述
要注意边界情况,如在#app上拿 p a r e n t 得到的是 n e w V u e ( ) 的实例,在这实例上再拿 parent得到的是new Vue()的实例,在这实例上再拿 parent得到的是newVue()的实例,在这实例上再拿parent得到的是undefined,而在最底层的子组件拿 c h i l d r e n 是个空数组。也要注意得到 children是个空数组。也要注意得到 children是个空数组。也要注意得到parent和 c h i l d r e n 的值不一样, children的值不一样, children的值不一样,children 的值是数组,而$parent是个对象
总结
上面两种方式用于父子组件之间的通信, 而使用props进行父子组件通信更加普遍; 二者皆不能用于非父子组件之间的通信。

3-Provide / reject

概念
provide/ reject 是vue2.2.0新增的api, 简单来说就是父组件中通过provide来提供变量, 然后再子组件中通过reject来注入变量。
特别注意
provide/ reject 不是响应式的,可能之所以这样设计,是为了避免数据的混乱。就如同props不能被子组件直接修改一样。

举例验证
假设有三个组件: A.vue、B.vue、C.vue 其中 C是B的子组件,B是A的子组件
在这里插入图片描述

4-Ref / refs

Ref
如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素,如果用在子组件上,引用就指向组件实例,可以通过实例直接调用组件的方法或访问数据
Refs
实例对象上的一个属性,用来保存被ref标记了的组件/DOM元素
在这里插入图片描述

5-eventBus

概念
eventBus 又称为事件 总线,在vue中可以使用它来作为沟通桥梁的概念, 就像是所有组件共用相同的事件中心,可以向该中心注册发送事件或接收事件, 所以组件都可以通知其他组件。

eventBus也有不方便之处, 当项目较大,就容易造成难以维护的灾难

在Vue的项目中怎么使用eventBus来实现组件之间的数据通信呢?具体通过下面几个步骤
初始化
首先需要创建一个事件总线并将其导出, 以便其他模块可以使用或者监听它.

发送事件
假设你有两个组件: additionNum 和 showNum, 这两个组件可以是兄弟组件也可以是父子组件;这里我们以兄弟组件为例:在这里插入图片描述
在这里插入图片描述
接收事件
在这里插入图片描述
移除事件监听者
如果想移除事件的监听, 可以像下面这样操作:
在这里插入图片描述

6-Vuex

https://www.bilibili.com/read/cv2898813/

7-localStorage / SessionStorage

这种通信比较简单,缺点是数据和状态比较混乱,不太容易维护。
通过window.localStorage.getItem(key)获取数据
通过window.localStorage.setItem(key,value)存储数据

注意用JSON.parse() / JSON.stringify() 做数据格式转换
localStorage / sessionStorage可以结合vuex, 实现数据的持久保存,同时使用vuex解决数据和状态混乱问题.

8-$attrs / $listeners

概念
在vue2.4中,为了解决该需求,引入了 a t t r s 和 attrs 和 attrslisteners , 新增了inheritAttrs 选项。 在版本2.4以前,默认情况下父作用域的不被认作props的属性百年孤独,将会“回退”且作为普通的HTML特性应用在子组件的根元素上。接下来看一个跨级通信的例子:
如果child-com1中的属性做为props:[‘name’]来接受
那么this.$attrs对象中将不再拿到name属性在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue,爷孙组件之间的数据传递是通过props和$emit来实现的。爷孙组件之间不能直接通信,需要通过父组件作为组件传递数据。具体实现步骤如下: 1. 在祖父组件(GrandFather.vue,定义要传递的数据msg1和msg2,并在模板将数据传递给父组件(Father)。 2. 在父组件(Father.vue,接收来自祖父组件的数据msg1和msg2,并将其作为props传递给子组件(GrandSon)。 3. 在子组件(GrandSon.vue,通过props接收来自父组件的数据msg1,并在需要的地方使用。 4. 如果子组件需要向爷爷组件传递数据,则在子组件通过$emit方法触发一个自定义事件,并将数据作为参数传递给爷爷组件。 5. 在爷爷组件,通过监听子组件的自定义事件,将接收到的数据绑定到data的reply属性上,以便在视图层渲染。 通过以上步骤,就可以实现Vue爷孙组件之间的数据传递。请注意,父组件作为组件传递数据的过程需要使用props,而子组件向父组件传递数据需要使用$emit方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Vue祖孙组件怎么传值](https://blog.csdn.net/qq_40738077/article/details/106765455)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值