当前位置: 首页 > news >正文

VUE3 provide 和 inject,跨越多层级组件传递数据

provideinject 是 Vue 3 提供的 API,主要用于实现祖先组件与后代组件之间的依赖注入。它们可以让你在组件树中,跨越多层组件传递数据,而不需要通过 props 或事件的方式逐层传递。这个机制主要用于状态共享、插件系统或某些跨层级的功能。

1. provide

provide 用来在祖先组件中提供数据或方法,这些数据和方法可以被任何后代组件注入。它可以在组件的 setup 函数中使用。

使用 provide
  • 在父组件或祖先组件中,调用 provide 来提供数据或方法。
  • 这些提供的数据可以在后代组件中被注入。

2. inject

inject 用来在后代组件中注入祖先组件提供的数据或方法。inject 也必须在 setup 函数中使用。

示例:

父组件(提供数据)
<template><ChildComponent />
</template><script setup>
import { provide } from 'vue'
import ChildComponent from './ChildComponent.vue'// 提供一个数据给后代组件
const message = "Hello from Parent!"
provide('message', message)
</script>
子组件(注入数据)
<template><p>{{ message }}</p>
</template><script setup>
import { inject } from 'vue'// 注入父组件提供的数据
const message = inject('message')
</script>

解释:

  1. 父组件 使用 provide 提供一个名为 message 的数据。
  2. 子组件 使用 inject 注入这个名为 message 的数据。

详细说明:

provide
  • provide 用来在组件中设置要共享的数据。
  • 可以共享任何类型的值,包括对象、数组、函数、字符串等。
  • 它是在组件的 setup() 函数中使用的(或者 Vue 2.x 中的 beforeCreate 和 created 生命周期钩子中)。
import { provide } from 'vue';provide('key', value);
inject
  • inject 使得子组件能够访问祖先组件通过 provide 提供的数据。
  • inject 可以在后代组件的 setup() 函数中使用。
  • inject 会查找父组件中使用 provide 提供的数据,并返回给当前组件。
import { inject } from 'vue';const value = inject('key');

高级用法:

1. 默认值

如果父组件没有提供某个值,inject 可以通过第二个参数提供默认值。

// 父组件中不提供 message
<template><ChildComponent />
</template><script setup>
import { provide } from 'vue'
import ChildComponent from './ChildComponent.vue'provide('message', 'Message from Parent') // 不传 message 时,使用默认值
</script>
// 子组件中使用 inject
<template><p>{{ message }}</p>
</template><script setup>
import { inject } from 'vue'// 如果父组件没有提供 message,使用默认值
const message = inject('message', 'Default Message')
</script>
2. 注入多个值:

可以注入多个值,甚至通过对象的方式一次性提供多个数据。

// 父组件
<template><ChildComponent />
</template><script setup>
import { provide } from 'vue'
import ChildComponent from './ChildComponent.vue'provide('state', { message: 'Hello', count: 10 })
</script>
// 子组件
<template><p>{{ state.message }}</p><p>{{ state.count }}</p>
</template><script setup>
import { inject } from 'vue'const state = inject('state')
</script>

总结:

  • provide 和 inject 是 Vue 3 中提供的用于跨组件传递数据的 API。
  • 它们的优势在于避免了通过 props 层层传递数据,简化了多层级组件间的通信。
  • provide 提供数据,inject 注入数据。
  • 它们通常用于插件、主题、配置等场景,也适用于跨越多层的组件树进行数据共享。
http://www.lryc.cn/news/519828.html

相关文章:

  • git打补丁
  • 机械燃油车知识图谱、知识大纲、知识结构(持续更新...)
  • Vue3学习总结
  • Type-C双屏显示器方案
  • 【读书与思考】焦虑与内耗
  • 基于python的网页表格数据下载--转excel
  • Vue.js开发入门:从零开始搭建你的第一个项目
  • LS1046+XILINX XDMA PCIE调通
  • HarmonyOS:@LocalBuilder装饰器: 维持组件父子关系
  • YOLOv10-1.1部分代码阅读笔记-downloads.py
  • 计算机图形学【绘制立方体和正六边形】
  • 基于django中医药数据可视化平台(源码+lw+部署文档+讲解),源码可白嫖!
  • kafka消费堆积问题探索
  • Vue.js 使用插槽(Slots)优化组件结构
  • Broker如何进行定时心跳发送和故障感知
  • 网络安全设备主要有什么
  • Android Framework WMS全面概述和知识要点
  • 记一次某红蓝演练经历
  • 一个运行在浏览器中的开源Web操作系统Puter本地部署与远程访问
  • 【零基础入门Go语言】struct 和 interface:Go语言是如何实现继承的?
  • 麦田物语学习笔记:实现拖拽物品交换数据和在地图上生成物品
  • 一些计算机零碎知识随写(25年1月)-1
  • Qt学习笔记第81到90讲
  • Centos9 + Docker 安装 MySQL8.4.0 + 定时备份数据库到本地
  • 网络原理一>UDP协议详解
  • MySQL的小问题
  • Mac——Docker desktop安装与使用教程
  • FastApi Swagger 序列化问题
  • 《机器学习》——sklearn库中CountVectorizer方法(词频矩阵)
  • UML系列之Rational Rose笔记三:活动图(泳道图)