【vue组件通讯的8种方式】

首先搭建好vue项目后

1.props和$emit

在components文件夹创建完成组件后引入页面注册后
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.ref传值

在这里插入图片描述
在这里插入图片描述

3.vuex

vuex是vue的状态管理工具 通过$store获取
比如 获取state中的vuex属性
在这里插入图片描述

4.localStorage/sessionStorage

在这里插入图片描述

在这里插入图片描述

5.eventBus

先创建一个js文件
然后在组件内引入 通过 e m i t 发 送 事 件 到 e v e n t B u s 文 件 中 再 通 过 emit 发送事件到eventBus文件中 再通过 emiteventBuson方法接受事件

// event-bus.js文件

import Vue from 'vue'
export const EventBus = new Vue()

like.vue 组件
在这里插入图片描述
hollo.vue 组件
在这里插入图片描述
在这里插入图片描述

6.$attrs与 $listeners

通常用来跨级通信
比如说 先定义一个A,B组件
在home页引入A组件 ,A组件内引入B组件
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7.$children/ $parent

$children直接获取当前实例的所有直接子组件 --数组形式

this.$children 可直接获取

$ parent: 子实例可以用 this.$parent 访问父实例

this.$parent获取父组件 不能跨级访问

8.provide/reject

用provide来声明数据 inject注入数据
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
页面效果
此处是 Home页面引入A组件, A组件引入B组件
页面效果 ↓↓↓
在这里插入图片描述
都显示成功
总结: 不论子组件嵌套有多深, 只要调用了inject 那么就可以注入provide中的数据,而不局限于只能从当前父组件的props属性中回去数据

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值