Vue3 中使用 provide/inject 实现跨层级组件传值失败的原因及解决方案

1、基础用法

父组件:

javascript 复制代码
<script setup>
import { ref, provide } from 'vue';
import ChildComponent from './ChildComponent.vue';
const parentData = ref('初始数据');
// 提供数据
provide('parentData', parentData);
</script>

子组件:

javascript 复制代码
<script setup>
import { inject } from 'vue';
// 注入父组件提供的数据
const parentData = inject('parentData');
</script> 
2、实际应用
基础用法只能满足一般的父子传值,但在实际项目中一般是动态触发事件或通过接口请求到数据后再传递给子级,provide和inject如果直接再调用接口的方法内传值会报警告,而且值也传递不过去。就是说provide()必须在setup根节点处才能使用,直接在方法里面用是不行的
解决方法:

通过将需要传递的值封装在一个方法中,父组件使用 provide() 提供这个方法而非直接传递值本身。子组件或孙组件通过 inject() 获取这个方法后,在需要时调用该方法来获取最新值。

父组件:

javascript 复制代码
const provideData = () => {
  return {
    name: name.value,
    age: age.value,
    total: () => total.value,
    address: () => address.value
  }
}
provide('provideData',provideData);

子组件:

javascript 复制代码
const provideData = inject('provideData');
const name= provideData().name;
const age = provideData().age;
const total = computed(() => provideData().total());
const address = computed(() => provideData().address());
相关推荐
Sylus_sui1 分钟前
鸿蒙Class实战:从零构建联系人列表
javascript
sudo_jin1 分钟前
从“输入网址”到“帧级控制”:我对事件循环与主线程管理的终极认知
前端·javascript
flyfox2 分钟前
Kiro AI IDE 深度使用指南:从入门到高效开发
前端·人工智能·ai编程
lovingsoft3 分钟前
Cursor Skills 实战教程:解锁AI编码效率,附多场景案例
前端·人工智能
Irene19914 分钟前
JavaScript中内置对象分类总结
javascript·内置对象
小凡同志7 分钟前
React vs Vue:两种前端架构哲学的深度解析
前端·vue.js
miss9 分钟前
Vue2 老项目上 TS?这 10 个坑我替你踩了,附完整迁移方案
前端
小码哥_常10 分钟前
RecyclerView深坑大揭秘:FlexboxLayoutManager引发的滑动误判
前端
Neptune111 分钟前
让我带你迅速吃透React组件通信:从入门到精通(中篇)
前端·react.js·面试
bluceli12 分钟前
CSS子选择器与伪类:精准控制元素样式的利器
前端·css