Vue3使用provide和inject实现孙组件给爷组件传递数据

前言:

最近在研究gitHub中的一个项目并将与自己之前完成的项目进行结合,其中有一个功能是需要在孙组件将数据传递给爷组件,笔者研究后将使用总结如下:

具体步骤:

1.爷组件先定义一个空的函数传递给孙子

2.孙组件使用inject接收

3.孙组件在函数中调用爷爷传递过来的函数,并在()中传递要传递的数据

4.调用这个函数(也可以使用点击事件等方式触发)

5.爷组件在当初定义的空函数中获得孙组件传递过来的值tValue

爷组件:

TypeScript 复制代码
<script lang="ts" setup>
import { ref, onMounted, provide } from "vue"
const tValue = ref("")
//1.爷组件先定义一个空的函数传递给孙子
provide("passValue", passValue)
//5.爷组件在当初定义的空函数中获得孙组件传递过来的值tValue
const passValue = (codeValue: string) => {
  tValue.value = value
}
console.log(tValue.value)
</script>

孙组件:

TypeScript 复制代码
<script lang="ts" setup>
import { inject } from "vue"
const value = 2000;
//2.孙组件使用inject接收
const passValue = inject("passValue")
//3.孙组件在函数中调用爷爷传递过来的函数,并在()中传递要传递的数据
const sendValue = () => {
  passValue(value)
}
//4.调用这个函数(也可以使用点击事件等方式触发)
sendValue()
</script>
相关推荐
木易 士心25 分钟前
Promise深度解析:前端异步编程的核心
前端·javascript
im_AMBER29 分钟前
Web 开发 21
前端·学习
又是忙碌的一天29 分钟前
前端学习day01
前端·学习·html
Joker Zxc33 分钟前
【前端基础】20、CSS属性——transform、translate、transition
前端·css
excel37 分钟前
深入解析 Vue 3 源码:computed 的底层实现原理
前端·javascript·vue.js
大前端helloworld1 小时前
前端梳理体系从常问问题去完善-框架篇(react生态)
前端
不会算法的小灰1 小时前
HTML简单入门—— 基础标签与路径解析
前端·算法·html
zero13_小葵司1 小时前
在Vue项目中构建后端配置的动态路由及权限控制体系
前端·javascript·vue.js
GISer_Jing1 小时前
前端框架篇——Vue&React篇
前端·javascript
面向星辰1 小时前
css其他选择器(精细修饰)
前端·css