Vue组件通信 - 组件传值 / 什么是组件

1.什么是组件通信:

组件(.vue)通过某种方式来传递信息以达到某个目的

2.组件通信可以解决什么问题:

每个组件之间都有独立的作用域,组件间的数据是无法共享的,但在实际开发中我们常常需要让组件之间共享数据,组件通讯可以让它们之间能进行通讯,这样才能构成完整的系统。

3.父子组件通信

3.1 方法一:props / $emit

父组件A通过props的方式向子组件B传递,B传A通过在B组件中$emit,A组件中v-on的方式实现。

3.2 方法二:$children / $parent

$children:获取到一个包含所有子组件(不包含孙组件)的VueComponent对象数组,可以直接拿到子组件中所有的数据和方法等

$parent: 获取到一个父节点的VueComponent 对象,同样包含父节点中所有数据和方法等

3.3 方法三 :$attrs / $listeners

$attrs:包含父作用域里除class 和 style 外的非props属性集合。通过 this.$attrs 获取父作用域中所有符合条件的属性集合,然后还要继续传给子组件内部的的其他组件,通过 v-bind = ' $attrs  '来实现

$listeners :包含父作用域里 .native 除外的监听事件集合。如果还要继续传给子组件内部的其他组件,就可以通过 v-on = ' $linteners'

4.同级组件通信

数据提升:A修改B,把B中的数据提升到公共的父组件里面,A通过子传父修改父亲的数据,父亲通过父传子传递把数据传递到B

5.跨层级组件通信

vuex全局状态共享

EventBus中央事件总线

不管是父子组件,兄弟组件,跨层级组件等都可以使用它完成通信操作

定义方法:

1.抽离成一个单独的js文件 Bus.js ,然后再需要的地方引入

1.1 A / B => import Bus from ' ./Bus.js '

1.2.A=> Bus.$emit(' 自定义事件名',' 传输的数据 ')

1.3.B =>Bus . $on (' 自定义事件名' ,function(接收的数据) {})

2.直接挂载到全局 Vue.prototype.$bus = new Vue()使用的时候$bus.

2.1 A=>this.$bus.$emit(' 自定义事件名',' 传输的数据 ')

2.2 B=> this.$bus.$on  (' 自定义事件名' ,function(接收的数据) {})

3.注入到Vue根对象上面 new Vue ({data: {Bus:new Vue()})

什么是组件:

组件就是把图形、非图形的各种逻辑均抽象为一个'统一的概念(组件)来实现开发的模式,在vue中每一个.vue文件都可以视为一个组件

组件的优势:

1.降低整个系统的耦合度,在保持接口不变的情况下,我们可以替换不同的组件快速完成需求

2.调试方便,由于整个系统是通过组件组合起来的,在出现问题的时候,可以用排除法直接移除组件,或者根据报错的组件快速定位问题,之所以能够快速定位,是因为每个组件之间的低耦合,职责单一,所以逻辑会比分析整个系统要简单

3.提高可维护性,由于每个组件的职责单一,并且组件在系统中是被复用的,所以对代码进行优化可以获得系统的整体升级

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

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

相关文章

【计算机网络原理】对传输层TCP协议的重点知识的总结

˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好,我是xiaoxie.希望你看完之后,有不足之处请多多谅解,让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN 如…

Spring Bean Map漫游:遍历背后的生命周期奥秘

1. 引言 在Spring框架中,Bean的生命周期是一个复杂而精妙的过程。其中,遍历存储Bean实例的Map(通常是DefaultSingletonBeanRegistry中的singletonObjects)是这一过程中的重要环节。理解这个遍历过程以及它在Bean生命周期中的作用…

桌面文件不见了怎么恢复?五种方法解决文件恢复难题,建议收藏

不小心误删除了桌面文件,导致文件丢失。事实上误删的文件并没有被永久删除,而是被移动到了回收站中,可以恢复这些文件。本文将分享多种方法,具体步骤如下。 方法一:从回收站中恢复 大多数操作系统都有回收站或垃圾桶的…

【C语言】结构体内存对齐:热门面试话题

🔥引言 书接上文,我们了解关于结构体的基本知识,这篇将深入剖析结构体中一个重要的知识点:内存对齐 关于内存对齐是属于热门面试话题,对此单独放在一篇来分享 🌈个人主页:是店小二呀 🌈C语言笔记…

3D工业视觉

前言 本文主要介绍3D视觉技术、工业领域的应用、市场格局等,主要技术包括激光三角测量、结构光、ToF、立体视觉。 一、核心内容 3D视觉技术满足工业领域更高精度、更高速度、更柔性化的需求,扩大工业自动化的场景。 2D视觉技术基于物体平面轮廓&#…

软件无线电学习-第二代移动通信系统过程理解

本文知识内容摘自《软件无线电原理和应用》 无线通信领域让大家感受最深的是民用移动通信的快速发展。民用移动通信在短短的二十年时间里已发展了三代:20世纪80年代的模拟体制(TACS/AMPS)为第一代移动通信(简称1G);20世纪90年代的数字体制(GSMCDMATDMA)…

Git提交和配置命令

一、提交代码到仓库 在软件开发中,版本控制是一个至关重要的环节。而Git作为目前最流行的版本控制系统之一,为我们提供了便捷高效的代码管理和协作工具。在日常开发中,我们经常需要将本地代码提交到远程仓库,以便于团队协作和版本…

2024电工杯数学建模B题思路模型代码

完整内容更新见文末名片 B 题:大学生平衡膳食食谱的优化设计及评价 大学时代是学知识长身体的重要阶段,同时也是良好饮食习惯形成的重要时期。这一特 定年龄段的年轻人,不仅身体发育需要有充足的能量和各种营养素,而且繁重的脑…

Java基础教程 - 9 集合

更好的阅读体验:点这里 ( www.doubibiji.com ) 更好的阅读体验:点这里 ( www.doubibiji.com ) 更好的阅读体验:点这里 ( www.doubibiji.com ) 9 集合 什么是集合&…

【stm32/CubeMX、HAL库】嵌入式实验六:定时器(2)|PWM输出

参考: 【【正点原子】手把手教你学STM32CubeIDE开发】 https://www.bilibili.com/video/BV1Wp42127Cx/?p13&share_sourcecopy_web&vd_source9332b8fc5ea8d349a54c3989f6189fd3 《嵌入式系统基础与实践》刘黎明等编著,第九章定时器&#xff0c…

爱普生TG5032SFN温补晶振在机器人控制中的应用

机器人控制是机器人技术的核心组成部分,它涉及通过传感器采集外部环境信息,然后经过信号处理、运动规划和执行控制等步骤,最终实现机器人的运动控制和任务执行。在技术的不断更选,机器人控制也在不断进步和演变。智能化机器人具备…

cannot compute sizeof(off_t) when compile netcdf-fortran

export LD_LIBRARY_PATH/netcdf-c/lib:$LD_LIBRARY_PATH

Z缓冲技术在AI去衣中的关键角色

引言: 人工智能(AI)技术的飞速发展,为图像处理领域带来了革命性的变化。其中,AI去衣技术作为一种新兴的应用,引起了广泛关注。它不仅在多媒体内容的编辑、虚拟现实和增强现实等领域具有重要的应用价值&…

Jenkins 构建 Maven 项目:项目和服务器在一起的情况

bash.sh内容 #!/bin/bash#删除历史数据 rm -rf ruoyi-admin.jar# appname$1 appnamevideo.xxxxx.com #获取传入的参数 echo "arg:$appname"#获取正在运行的jar包pid # pidps -ef | grep $1 | grep java -jar | awk {printf $2} pidps -ef | grep $appname | grep ja…

1673. 找出最具竞争力的子序列

题目 给定一个整数数组 nums 和一个正整数 k,返回长度为 k 且最具竞争力的 nums 子序列。 数组的子序列是从数组中删除一些元素(可能不删除元素)得到的序列。 在子序列 a 和子序列 b 第一个不相同的位置上,如果 a 中的数字小于…

mysql 删除特殊字符 表中存了特殊字符 换行符 回车符 word字符 查询不到

省流: UPDATE t1 SET f1 REPLACE(REPLACE( f1 , CHAR(10), ), CHAR(13), ); 用 replace() 函数将 换行符char(10) 和 回车符char(13) 替换为空字符串。 char(10):换行 char(13):回车 发现表里存进很多换行符,如下图&#xff1a…

深入研究Qt Meta - Object System

目录 先说RTTI 再说QMeta Object System 关于Q_OBJECT 这篇文章我打算研究一下QMetaObject System,也就是Qt自己构建起来的元对象系统。 先说RTTI 啥是RTTI?这是C编程里的一个常见术语,全称是:运行阶段类型识别(Ru…

Chrome DevTools攻略

Chrome DevTools,也称为Chrome开发者工具,是一套直接内置于Google Chrome浏览器的Web开发者工具。以下是一些使用Chrome DevTools的攻略和技巧: 打开DevTools: 右键点击页面上的任何元素,选择“检查”或“审查元素”。…

2024年华为OD机试真题-机场航班调度程序-C++-OD统一考试(C卷D卷)

题目描述: XX市机场停放了多架飞机,每架飞机都有自己的航班号CA3385,CZ6678,SC6508等,航班号的前2个大写字母(或数字)代表航空公司的缩写,后面4个数字代表航班信息。但是XX市机场只有一条起飞用跑道,调度人员需要安排目前停留在机场的航班有序起飞。为保障航班的有序起…

【webrtc】MediaEngine的实现CompositeMediaEngine创建VOE

m98音视频的引擎是管理channel的看起来是外部强加给CompositeMediaEngine 管理的。CompositeMediaEngine :合成媒体引擎 G:\CDN\rtcCli\m98\src\media\base\media_engine.h// CompositeMediaEngine constructs a MediaEngine from separate // voice and video engine classes…