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>
相关推荐
之恒君3 小时前
React 性能优化(方向)
前端·react.js
coding随想3 小时前
JavaScript Notifications API:告别alert弹窗,开启沉浸式用户体验革命!
开发语言·javascript·ux
钝挫力PROGRAMER3 小时前
Vue中选项式和组合式API的学习
javascript·vue.js
3秒一个大3 小时前
Vue 任务清单开发:数据驱动 vs 传统 DOM 操作
前端·javascript·vue.js
阿蒙Amon3 小时前
JavaScript学习笔记:2.基础语法与数据类型
javascript·笔记·学习
an86950013 小时前
vue自定义组件this.$emit(“refresh“);
前端·javascript·vue.js
Avicli3 小时前
Gemini3 生成的基于手势控制3D粒子圣诞树
前端·javascript·3d
GinoWi3 小时前
HTML标签 - 列表标签
前端
o__A_A3 小时前
渲染可配置报告模板+自适应宽度(vue3)
前端·vue.js
鹏北海3 小时前
Vue 组件解耦实践:用回调函数模式替代枚举类型传递
前端·vue.js