学习vue3:跨组件通信(provide+inject)

目录

一,关于跨组件通信概述

二,跨组件传值

[案例1(爷传孙)](#案例1(爷传孙))

三,跨组件传函数

[案例2(爷传孙)](#案例2(爷传孙))

疑问:孙子传给爷爷是否可行呢?


一,关于跨组件通信概述

之前我们学习了父子组件的传值,它仅仅只是两个组件嵌套传递数据,跨组件通信,则是多个组件传递数据。如:现在有三个组件:App.vue,father.vue,son.vue,我把App.vue看作爷爷,father.vue看作父亲,son.vue看作儿子。现在我要将数据从爷爷传给孙子,就可以使用跨组件通信。

提示

跨组件通信:使用 provide+inject的方式适用于需要跨层级共享数据的场景

但需注意不要滥用。如果组件层级较深,且需要在多个组件之间共享状态,可以使用 Vuex 或 Pinia 等状态管理工具(后面也会讲)


二,跨组件传值

案例1(爷传孙)

App.vue

html 复制代码
<script setup>
import father from './views/father.vue';
import { provide,ref,reactive} from 'vue';
const data=ref(1234567890)
const dataObj=reactive({name:'张三',age:20})
provide('data',data)
provide('dataObj',dataObj)
</script>
<template>
<father></father>
</template>


<style scoped>

</style>

father.vue

html 复制代码
<template>

    <div>

爷爷传给父亲的基本数据值:{{ father }}
   <br/>
爷爷传给父亲的对象值:{{ father1 }}

  </div>

</template>



<script setup>

import { inject,ref } from 'vue';

const father = inject('data');

const father1 = inject('dataObj');

const a=ref('')

a.value=father.value

console.log(a.value)

a.value=father1.name

console.log(a.value)

</script>



<style lang="scss" scoped>

</style>

son.vue

html 复制代码
<template>
    <div>
爷爷传给孙子的基本数据:{{ parent }}
        <br>
        爷爷传给孙子的对象数据:{{ parent2 }}
    </div>
</template>

<script setup>
import { inject } from 'vue';
const parent = inject('data');
const parent2 = inject('dataObj');
console.log(parent2);
</script>

<style lang="scss" scoped>

</style>

测试结果

三,跨组件传函数

案例2(爷传孙)

son.vue

html 复制代码
<template>
    <button @click="count">爷爷传递的函数</button>
</template>

<script setup>
import { inject ,provide,ref} from 'vue';
const count=inject('count')
</script>

<style lang="scss" scoped>

</style>

App.vue

html 复制代码
<script setup>
import father from './views/father.vue';
import { provide, inject,ref,reactive} from 'vue';
const count=ref(0)
const countNum=()=>{
    count.value++
}
provide('count',countNum)
</script>

<template>
<father>
</father>
<br/>
<h4>当孙子点击爷爷发送自增函数,数据:{{ count }}</h4>
</template>

<style scoped>

</style>

测试结果

总结:跨组件通信,无法做到孙子传给爷爷,但在组件中可以多次使用provide 或inject函数


疑问:孙子传给爷爷是否可行呢?

案例3(孙传爷)

son.vue

html 复制代码
<template>
    <div>
        爷爷传给孙子的基本数据:{{ parent }}
        <br>
        爷爷传给孙子的对象数据:{{ parent2 }}
    </div>
</template>

<script setup>
import { inject ,provide,ref} from 'vue';
const parent = inject('data');
const parent2 = inject('dataObj');
console.log(parent2);
const son = ref(11111)
provide("dataSon",son)
</script>

<style lang="scss" scoped>

</style>

App.vue

html 复制代码
<script setup>
import father from './views/father.vue';
import { provide, inject,ref,reactive} from 'vue';
const data=ref(1234567890)
const dataObj=reactive({name:'张三',age:20})
provide('data',data)
provide('dataObj',dataObj)
const son=inject('dataSon')
console.log("son:",son)
</script>

<template>
<father>
</father>
</template>

<style scoped>

</style>

测试结果

相关推荐
三品吉他手会点灯38 分钟前
C语言学习笔记 - 50.流程控制4 - 流程控制为什么非常非常重要
c语言·开发语言·笔记·学习
云飞云共享云桌面2 小时前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
UXbot2 小时前
如何选择适合公司项目的UI设计工具?企业选型指南
前端·低代码·ui·团队开发·原型模式·设计规范·web app
llz_1122 小时前
web-第四次课后作业
前端·spring boot·web
sunfdf3 小时前
知识学习场景下的智能应用实践大纲
学习
武清伯MVP3 小时前
前端跨域方案大合集
前端·javascript
一杯奶茶¥3 小时前
基于springboot的失物招领管理系统带万字文档 校园失物招领管理系统 失物认领管理系统java springboot vue
java·vue.js·spring boot·java项目
小刘|4 小时前
Spring AI Alibaba 集成和风天气 API 实战
java·服务器·前端
星星在线4 小时前
我是怎么把页面图片流量砍掉一半的
前端·javascript
MartinYeung54 小时前
[论文学习]重新思考大型语言模型忘却目标:梯度视角与超越
人工智能·学习·语言模型