Vue3 provide 和 inject 实现祖组件和后代组件通信

provide 和 inject 能够实现祖组件和其任意的后代组件之间通信:

一、provide 提供数据

我们在祖组件中使用provide 将数据提供出去。

使用provide 之前需要先进行引入:

import { provide } from "vue";

语法格式如下:

provide("数据名", 数据)

例如:我们将祖组件中的person 使用provide提供出去

javascript 复制代码
setup() {
  let person = reactive({
    name: "张三",
    age:18
  })

  provide("person", person);  // 将perosn 提供出去

  return {
    person
  }
}

二、inject 使用数据

我们在后代组件中使用inject 来使用数据。

使用inject之前需要在该组件中对其进行引入:

import { inject } from "vue";

使用语法:

let xxx = inject("数据名") ;

我们在后代组件中接受上面祖组件提供的person 数据

javascript 复制代码
setup() {
  let person = inject("person");

  return {
    person
  }
}
相关推荐
欣然~1 天前
法律案例 PDF 批量转 TXT 工具代码
linux·前端·python
一个小废渣1 天前
Flutter Web端网络请求跨域错误解决方法
前端·flutter
鸣弦artha1 天前
Flutter框架跨平台鸿蒙开发——Extension扩展方法
android·javascript·flutter
符文师1 天前
css3 新特性
前端·css3
ct9781 天前
WebGL开发
前端·gis·webgl
C_心欲无痕1 天前
前端页面渲染方式:CSR、SSR、SSG
前端
果粒蹬i1 天前
生成式 AI 质量控制:幻觉抑制与 RLHF 对齐技术详解
前端·人工智能·easyui
筱歌儿1 天前
TinyMCE-----word表格图片进阶版
开发语言·javascript·word
Ama_tor1 天前
obsidian进阶の插件系列|Templater从小白到菜鸟
javascript·markdown·插件·obsidian
WordPress学习笔记1 天前
解决Bootstrap下拉菜单一级链接无法点击的问题
前端·bootstrap·html