Vue3基础知识:组合式API中的provide和inject,他们作用是什么?如何使用?以及案例演示

1.provide和inject相较于父子传递的不同在于provide,inject可以用于跨层级通信(通俗易懂的讲就是可以实现爷孙之间的直接信息传递)。

1.跨层级传递数据

1.在顶层组件通过provide函数提供数据

2.底层组件通过inject函数获取数据

演示一:跨层传递普通数据。

效果图:

演示二:跨层传递动态数据。

效果图:

3.最后附上源代码:

爷爷组件App.vue
javascript 复制代码
<script setup>
import Father from './components/Father.vue';
import { provide ,ref} from 'vue';

//传递普通数据
provide('HairColor','black')

//传递相应式数据
const count=ref(100)
provide('count',count)

//跨层级传递函数
provide('changeCount',(SonInfo)=>{
  count.value--
  console.log(SonInfo)
})
</script>



<template>
  <div>
    <h1>这个是爷爷</h1>
    <father></father>
  </div>
</template>



<style lang="scss" scoped>

</style>
父亲组件Father.vue
javascript 复制代码
<script setup>
import Son from './Son.vue';
</script>


<template>
    <div>
        <h2>这里是爸爸</h2>
        <Son></Son>
    </div>
</template>



<style lang="scss" scoped>

</style>
孙子组件Son.vue
javascript 复制代码
<script setup>
import { inject } from 'vue';
const HairColor=inject('HairColor')

//
const count=inject('count')

const ChangeCount=inject('changeCount')
const clickFn=()=>{
    ChangeCount('传给父亲的数据')
}
</script>



<template>
    <div>
        <h3>这里是儿子---爷爷头发的颜色---{{HairColor}} 年龄为:{{count}}岁</h3>
        <button @click="clickFn">年龄减一</button>
    </div>
</template>



<style lang="scss" scoped>

</style>
相关推荐
崔庆才丨静觅7 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅7 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment7 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅8 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊8 小时前
jwt介绍
前端
爱敲代码的小鱼8 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
吹牛不交税8 小时前
admin.net-v2 框架使用笔记-netcore8.0/10.0版
vue.js·.netcore
Cobyte8 小时前
AI全栈实战:使用 Python+LangChain+Vue3 构建一个 LLM 聊天应用
前端·后端·aigc
NEXT068 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
剪刀石头布啊8 小时前
生成随机数,Math.random的使用
前端