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>
相关推荐
孤水寒月2 小时前
基于HTML的悬窗可拖动记事本
前端·css·html
祝余呀2 小时前
html初学者第一天
前端·html
脑袋大大的3 小时前
JavaScript 性能优化实战:减少 DOM 操作引发的重排与重绘
开发语言·javascript·性能优化
速易达网络4 小时前
RuoYi、Vue CLI 和 uni-app 结合构建跨端全家桶方案
javascript·vue.js·低代码
耶啵奶膘5 小时前
uniapp+firstUI——上传视频组件fui-upload-video
前端·javascript·uni-app
JoJo_Way5 小时前
LeetCode三数之和-js题解
javascript·算法·leetcode
视频砖家5 小时前
移动端Html5播放器按钮变小的问题解决方法
前端·javascript·viewport功能
lyj1689975 小时前
vue-i18n+vscode+vue 多语言使用
前端·vue.js·vscode
小白变怪兽7 小时前
一、react18+项目初始化(vite)
前端·react.js
ai小鬼头7 小时前
AIStarter如何快速部署Stable Diffusion?**新手也能轻松上手的AI绘图
前端·后端·github