Vue3:组件间通信-provide和inject实现祖先组件与后代组件间直接通信

一、情景说明

我们学习了很多的组件间通信

这里在学习一种,祖先组件与后代组件间通信的技术

这里的后代,可以是多层继承关系,子组件,子子组件,子子子组件等等。

  • 在祖先组件中通过provide配置向后代组件提供数据
  • 在后代组件中通过inject配置来声明接收数据

二、案例

1、父组件

javascript 复制代码
  import { ref,reactive,provide } from "vue";
  // 数据
  let money = ref(100)
  let car = reactive({
    brand:'奔驰',
    price:100
  })
  // 用于更新money的方法
  function updateMoney(value:number){
    money.value += value
  }
  // 提供数据
  provide('moneyContext',{money,updateMoney})
  provide('car',car)

2、子子组件

接收到之后,就可以当成自己的变量直接操作了

javascript 复制代码
  import { inject } from 'vue';
  // 注入数据
 let {money,updateMoney} = inject('moneyContext',{money:0,updateMoney:(x:number)=>{}})
  let car = inject('car')

注意,我们可以发现,provide可以传递变量,也可以传递函数

当传递函数的时候,后代组件就可以调用该祖先组件的函数,从而,间接的操作祖先组件中的变量

实现,反向通信

相关推荐
然我5 分钟前
别再只用 base64!HTML5 的 Blob 才是二进制处理的王者,面试常考
前端·面试·html
NanLing7 分钟前
【纯前端推理】纯端侧 AI 对象检测:用浏览器就能跑的深度学习模型
前端
呆呆的心9 分钟前
前端必学:从盒模型到定位,一篇搞定页面布局核心 🧩
前端·css
小飞悟9 分钟前
前端高手才知道的秘密:Blob 居然这么强大!
前端·javascript·html
小old弟10 分钟前
用Sass循环实现炫彩文字跑马灯效果
前端
code_YuJun10 分钟前
Promise 基础使用
前端·javascript·promise
Codebee10 分钟前
OneCode自主UI设计体系:架构解析与核心实现
前端·javascript·前端框架
GIS之路13 分钟前
GIS 空间关系:九交模型
前端
邢同学爱折腾14 分钟前
当前端轮播图遇上Electron: 变身一款丝滑的 图片查看器
javascript·electron
xiguolangzi20 分钟前
vue3+element-plus el-table列的显隐、列宽 持久化
前端·javascript·vue.js