前端基础之《Vue(14)—组件通信(1)》

一、什么是组件通信

1、通信是组件或模块之间的数据交互。

2、组件多重通信就形成了数据流,数据流管理的优劣决定了产品能否上线,返工是否频繁的问题。

3、Vue中有哪些常见的通信方案?

组件树的概念:
在Vue中,组件树(Component Tree)指的是一个由多个嵌套的Vue组件组成的层级结构。每个组件可以是另一个组件的子组件,这样层层嵌套形成一棵树。这种结构允许开发者构建复杂和可重用的用户界面。

(1)父子组件通信
父传子使用自定义属性(使用props接收),子传父使用自定义事件(使用$emit)。

(2)状态提升
状态就是数据的意思。
当兄弟组件之间需要共享数据时,我们通常的做法是把这个数据定义在它们的共同的父组件中,再通过自定义属性实现数据共享。

(3)provide/inject通信
这是一种在组件树间自上而下的一种数据通信方案。
也就是说,只能从父级组件中向后代组件传递。
是Vue提供的两个内置选项,可以对象写法,也可以function写法。

需要注意的是,当provide提供动态数据(声明式变量)时,动态数据发生变化,后代组件们不会自动更新,这是为什么呢?
因为生命周期流程中,是在beforeCreate()和created()之间,inject注入provide数据。
所以下面在例子代码里,更新父组件中的provide数据,子组件不会更新!!!

(4)ref通信
ref是Vue内置的一个属性,就像id、class一样,每一个HTML元素或组件都有这个属性。
ref作用在HTML元素上,得到DOM实例,ref作用在组件上得到组件实例。
使用ref访问组件实例,可以进一步访问组件中的数据和方法。

ref是一种快捷的DOM访问方式,当然ref也可以作用在组件上得到组件实例对象。这些ref得到的DOM实例或组件实例,使用this.$refs来访问它们。
ref尽量少用,除非某些难搞的需求。

(5)slot插槽通信
从子组件向父组件传递数据,在父组件的插槽中,使用#default='scoped'访问子组件<slot>回传的数据。
子组件访问插槽,借助this.$slots访问父组件中的插槽实例。
这种通信在组件库中、工作中,非常常见。

注意:在自定义插槽<comp-child-e>包起来的内容是父组件的。

(6)$parent/$children通信
借助$parent/$children这两个API,可以实现在任一组件中访问组件树中的其它任意组件实例。可以做到在组件中随意穿梭。

$parent表示的是当前组件的父组件实例对象。
$children表示的是当前组件的子组件们。

(7)$attrs/$listeners通信
借助$attrs可以访问父组件传递过来的自定义属性(除了class和style外)。
借助$listeners可以访问父组件给的自定义事件。
在某些场景下,$attrs/$listeners可以替代props/$emit()这种通用的通信方式。

(8)事件总线
借助Vue内置的事件系统。($on/$emit/$off/$once)实现“订阅-发布”模式的通信。这种通信方式是一对多的,且与组件的层级无关。

(9)Vuex通信
这是Vue架构中终极的通信方案,也是Vue架构中用的最多的一种通信方式。

二、状态提升例子

有一个变量大哥点了加1,二哥点了减1。

<html>
<head><title>组件通信-状态提升</title><style></style>
</head>
<body><div id="app"><comp-child-a :numa="num" @add="num+=$event"></comp-child-a><hr><comp-child-b :numb="num" @sub="num-=$event"></comp-child-b><hr></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>Vue.component('comp-child-a', {template: `<div><div>大哥  {{numa}}</div><button @click='$emit("add", 1)'>加1</button></div>`,props: {numa: {type: Number, default: 0}}})Vue.component('comp-child-b', {template: `<div><div>二哥  {{numb}}</div><button @click='$emit("sub", 1)'>减1</button></div>`,props: {numb: {type: Number, default: 0}}})const app = new Vue({// 变量定义在父组件中data() {return {num: 1}}})app.$mount('#app')</script></body>
</html>

三、provide/inject例子

注意:provide提供声明式变量numf,如果在父组件中修改了app.num的值,子组件中不会改变!!!

<html>
<head><title>组件通信-provide/inject</title><style></style>
</head>
<body><div id="app"><comp-child-c></comp-child-c></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>Vue.component('comp-child-c', {template: `<div><div>三哥 {{msg}} - {{numf}}</div><span v-for='i in list' v-text='i'></span></div>`,// 从组件树的上下文中注入provide的数据inject: ['msg','list','numf']})const app = new Vue({// 变量定义在父组件中data() {return {num: 1}},// 从当前组件节点开始,向后代组件们传递数据// 工作中更推荐function写法,因为可以用this// provide: {//     msg: "你好",//     list: [1,2,3,4]// }provide() {return {msg: '你好',list: [1,2,3,4],numf: this.num // 动态数据}}})app.$mount('#app')</script></body>
</html>

四、ref例子

<html>
<head><title>组件通信-ref</title><style></style>
</head>
<body><div id="app"><div ref='box'>普通HTML标签</div><comp-child-d ref='dd'></comp-child-d><button @click='handle'>测试ref操作</button></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>Vue.component('comp-child-d', {template: `<div><div>四哥  {{age}}</div></div>`,data() {return {age: 10}},methods: {changeAge(arg) {this.age = arg || 10}}})const app = new Vue({// 变量定义在父组件中data() {return {num: 1}},methods: {handle() {console.log('---refs', this.$refs)this.$refs.box.style.color = 'red'this.$refs.dd.changeAge(20)}}})app.$mount('#app')</script></body>
</html>

点击按钮:

获取到DOM实例和组件实例:

五、插槽例子

在Vue中,凡是被包裹在自定义组件内部的东西,都是插槽内容。

问题:插槽加上作用域后,子组件内插槽内的this.$slots拿不到父组件内的插槽内容?
解答:加了作用域后,要取$scopedSlots属性。

<html>
<head><title>组件通信-插槽</title><style></style>
</head>
<body><div id="app"><comp-child-e><template #default='scoped'><div>别墅一栋  {{scoped.foo}}  {{scoped.bar}}</div></template><template #car='scoped'><div>{{scoped.car2}}专用车位</div></template></comp-child-e></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>Vue.component('comp-child-e', {template: `<div><div>五哥</div><slot name='default' foo='你好' bar='世界'><div>我的房子</div>    </slot><slot name='car' :car2='car1'><div>我的车位</div></slot></div>`,data() {const cars = ['宝马','奔驰']const val = cars[Math.floor(Math.random()*2)]return {car1: val}},mounted() {// 在子组件中使用this.$slots来访问父组件给的插槽内容//console.log('---this', this)console.log('---slot', this.$slots)console.log('---scoped slot', this.$scopedSlots)}})const app = new Vue({})app.$mount('#app')</script></body>
</html>

页面显示:

控制台:

六、$parent/$children例子

<html>
<head><title>组件通信-$parent/$children</title><style></style>
</head>
<body><div id="app"><comp-child-f></comp-child-f></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>Vue.component('comp-child-f', {template: `<div><div>六哥  {{num}}</div></div>`,data() {return {num: 1}},methods: {add() {this.num++}}})const app = new Vue({mounted() {console.log('app---$parent', this.$parent)console.log('app---$children', this.$children)}})app.$mount('#app')</script></body>
</html>

页面显示:

控制台修改num:

页面变化:

七、$attrs/$listeners例子

<html>
<head><title>组件通信-$attrs/$listeners</title><style>.page span {display: inline-block;padding: 0 10px;cursor: pointer;}.page span.on {color: red;}</style>
</head>
<body><div id="app"><comp-child-g :page='page' @change='changePage'></comp-child-g></div><script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script><script>Vue.component('comp-child-g', {template: `<div class="page"><div>七哥</div><span v-for='i in pageArr' v-text='i' :class='{on:$attrs.page===i}' @click='$listeners.change(i)'></span></div>`,// 这里不用props接收,用attrsmounted() {console.log('g---attrs', this.$attrs)console.log('g---listeners', this.$listeners)},computed: {pageArr() {const p = this.$attrs.pageif (p<=3) return [1,2,3,4,5]else return [p-2,p-1,p,p+1,p+2]}}})const app = new Vue({data() {return {page: 1}},methods: {changePage(reg) {this.page = reg || 1}}})app.$mount('#app')</script></body>
</html>

页面显示:

控制台修改page:

页面变化:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/904450.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

el-row el-col

参考layout布局 Element - The worlds most popular Vue UI frameworkElement&#xff0c;一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库https://element.eleme.cn/#/zh-CN/component/layout#row-attributes 一行可以看做24个 Element UI 中的 el-row 是…

Socket-TCP

在TCP/ip协议中&#xff0c;用源IP、源端口号、目的IP、目的端口号、协议号这样一个五元组来标识一个通信&#xff01; 端口号范围划分 0 - 1023: 知名端口号&#xff0c;HTTP&#xff0c;FTP&#xff0c;SSH 等这些广为使用的应用层协议&#xff0c;他们的端口号都是固定的。…

大数据Spark(五十八):Spark Pi介绍

文章目录 Spark Pi介绍 Spark Pi介绍 Spark Pi是Apache Spark官方提供的一个示例程序&#xff0c;该案例使用 Spark 进行分布式计算&#xff0c;通过蒙特卡罗方法估算圆周率&#xff08;π&#xff09;的值&#xff0c;其估算π原理如下&#xff1a; 上图中&#xff0c;正方形…

Doris索引机制全解析,如何用高效索引加速数据分析

在当今大数据时代&#xff0c;企业对于实时数据分析的需求呈现爆发式增长。面对动辄PB级的数据量和秒级响应的业务诉求&#xff0c;传统数据库系统往往力不从心。Apache Doris作为新一代MPP分析型数据库&#xff0c;凭借其独特的索引机制&#xff0c;在京东、美团等企业的实时数…

基于SpringBoot + Vue 的作业管理系统

产品包含&#xff1a; 项目源码数据库文件论文ppt 技术栈 架构: B/S、MVC 系统环境&#xff1a;Windows/Mac 开发环境&#xff1a;IDEA、JDK1.8、Maven、Mysql 技术栈&#xff1a;Java、Mysql、SpringBoot、Mybatis、Vue 功能模块 用户模块&#xff1a;学生用户、管理员、…

HCL(HashiCorp Configuration Language)是一种结构化配置语言

HCL&#xff08;HashiCorp Configuration Language&#xff09;是一种结构化配置语言&#xff0c;语法简洁且可读性强&#xff0c;广泛用于 Docker Buildx Bake、Terraform、Nomad 等工具的配置。以下是其核心语法规则和示例&#xff1a; 1. 基础结构 HCL 使用 块&#xff08;…

《AI大模型应知应会100篇》第50篇:大模型应用的持续集成与部署(CI/CD)实践

第50篇&#xff1a;大模型应用的持续集成与部署&#xff08;CI/CD&#xff09;实践 &#x1f9fe; 摘要 在AI大模型开发中&#xff0c;随着模型版本迭代频繁、依赖复杂、部署环境多样&#xff0c;构建一套高效可靠的持续集成与持续交付&#xff08;CI/CD&#xff09;流程显得尤…

【Linux深入浅出】之全连接队列及抓包介绍

【Linux深入浅出】之全连接队列及抓包介绍 理解listen系统调用函数的第二个参数简单实验实验目的实验设备实验代码实验现象 全连接队列简单理解什么是全连接队列全连接队列的大小 从Linux内核的角度理解虚拟文件、sock、网络三方的关系回顾虚拟文件部分的知识struct socket结构…

DB-GPT V0.7.1 版本更新:支持多模态模型、支持 Qwen3 系列,GLM4 系列模型 、支持Oracle数据库等

V0.7.1版本主要新增、增强了以下核心特性 &#x1f340;DB-GPT支持多模态模型。 &#x1f340;DB-GPT支持 Qwen3 系列&#xff0c;GLM4 系列模型。 &#x1f340; MCP支持 SSE 权限认证和 SSL/TLS 安全通信。 &#x1f340; 支持Oracle数据库。 &#x1f340; 支持 Infini…

2025五一数学建模竞赛A题完整分析论文(共45页)(含模型、可运行代码、数据)

2025年五一数学建模竞赛A题完整分析论文 摘 要 一、问题分析 二、问题重述 三、模型假设 四、符号定义 五、 模型建立与求解 5.1问题1 5.1.1问题1思路分析 5.1.2问题1模型建立 5.1.3问题1参考代码 5.1.4问题1求解结果 5.2问题2 5.2.1问题2思路分析 …

[学习]RTKLib详解:pntpos.c与postpos.c

文章目录 RTKLib详解&#xff1a;pntpos.c与postpos.cPart A: pntpos.c一、概述二、整体工作流程三、主要函数说明1. pntpos()2. satposs()3. estpos()4. rescode()5. prange()6. ionocorr()7. tropcorr()8. valsol()9. raim_fde()10. estvel() 四、函数调用关系图&#xff08;…

【科研绘图系列】R语言绘制世界地图(map plot)

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍加载R包数据下载导入数据数据预处理画图输出图片系统信息介绍 【科研绘图系列】R语言绘制世界地图(map plot) 加载R包 library(ggmap) library(RColorBrewer) library(pals) …

在pycharm profession 2020.3上安装使用xlwings

之前写了一篇文章在win7和python3.8上安装xlwings-CSDN博客 今天安装了pycharm profession 2020.3&#xff0c;自带Terminal&#xff0c;所以试一下安装xlwings。 一、新建一个python项目 二、安装xlwings 三、输入安装命令 pip3.exe install -i https://pypi.tuna.tsinghu…

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】4.3 数据脱敏与安全(模糊处理/掩码技术)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 PostgreSQL数据脱敏实战&#xff1a;从模糊处理到动态掩码的全流程解析4.3 数据脱敏与安全&#xff1a;模糊处理与掩码技术深度实践4.3.1 数据脱敏的核心技术体系4.3.1.1 技…

坚鹏:平安保险集团《保险行业发展趋势与AI应用方法及案例》培训

坚鹏&#xff1a;平安保险集团《保险行业发展趋势与AI应用方法及案例》培训圆满成功 中国平安保险&#xff08;集团&#xff09;股份有限公司是全球领先的综合金融生活服务集团&#xff0c;2024年位列《财富》世界500强第16位&#xff0c;连续多年蝉联全球保险品牌价值榜首。截…

NetSuite 2025.1 学习笔记

目录 领域、新功能统计表 值得注意功能摘要 最有价值功能详解 1. 领域、新功能统计表 2. 值得注意功能 3. 最有价值功能 3.1 Customer 360 目前的Customer 360在加入了几个新的控件后&#xff0c;变得完整了&#xff0c;相比较过去&#xff0c;真正有了实用感。 3.2 CSV Im…

Messenger.Default.Send 所有重载参数说明

Messenger.Default.Send 是 MVVM 框架中实现消息传递的核心方法,其重载参数主要用于控制消息的发送范围和接收条件。以下是其所有重载形式及参数说明: ‌1. 基本消息发送‌ Send<TMessage>(TMessage message) ‌参数说明‌: TMessage:消息类型(泛型参数),可以是任…

代码异味(Code Smell)识别与重构指南

1、引言:什么是“代码异味”? 在软件开发中,“代码异味(Code Smell)”是指那些虽然不会导致程序编译失败或运行错误,但暗示着潜在设计缺陷或可维护性问题的代码结构。它们是代码演进过程中的“信号灯”,提示我们某段代码可能需要优化。 1.1 ✅ 为什么关注代码异味? 预…

K8S有状态服务部署(MySQL、Redis、ES、RabbitMQ、Nacos、ZipKin、Sentinel)

K8S部署MySQL ①、创建配置 ②、创建存储卷 ③、创建服务 指定配置文件 指定存储卷 ④、同样的方式创建mysql-slaver服务&#xff08;配置文件和mysql-master不同&#xff09; ⑤、进行主从同步关联 进入master服务中 进入从库的终端 K8S部署Redis…

正则表达式与文本三剑客grep、sed、awk

目录 一、正则表达式 1.1、字符匹配 1.2、次数匹配 1.3、位置锚定 1.4、分组或其他 二、扩展正则表达式 三、grep 四、awk 4.1、常用命令选项 4.2、工作原理 4.3、基础用法 4.4、内置变量 4.5、模式 4.6、条件判断 4.7、awk中的循环语句 4.8、数组 4.9、脚本 …