vue组件中各种类型之间的传值
在Vue CLI项目中,组件间的属性传值是一个常见的需求。以下是一些常用的传值方法和规范,以及相应的代码演示和解说:
一. 父组件向子组件传值(Props)
-
规范:父组件通过属性(props)向子组件传递数据。子组件需要在
props选项中声明这些属性。 -
代码演示:
(1) 父组件:
<template><div><child-component :parent-data="dataFromParent"></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},data() {return {dataFromParent: '这是来自父组件的数据'};}
};
</script>
(2) 子组件:
<template><div>{{ parentData }}</div>
</template><script>
export default {props: {parentData: String}
};
</script>
- 解说:父组件使用
v-bind(或简写为:)将dataFromParent属性传递给子组件。子组件通过声明props来接收这个数据,并可以在模板中使用它。
二. 子组件向父组件传值(Events)
-
规范:子组件通过发射事件(
$emit)向父组件传递数据。父组件通过监听这些事件来接收数据。 -
代码演示:
(1)子组件:
<template><div><button @click="sendDataToParent">发送数据到父组件</button></div>
</template><script>
export default {methods: {sendDataToParent() {this.$emit('dataToSend', '这是子组件发送的数据');}}
};
</script>
(2)父组件:
<template><div><child-component @dataToSend="handleDataFromChild"></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},methods: {handleDataFromChild(data) {console.log(data); // 输出:这是子组件发送的数据}}
};
</script>
- 解说:子组件通过
this.$emit触发一个事件,并传递数据。父组件通过v-on(或简写为@)监听这个事件,并在事件处理函数中接收数据。
三. 兄弟组件传值(Event Bus)
-
规范:兄弟组件可以通过一个共同的父组件或使用全局事件总线(Event Bus)来传递数据。
-
代码演示:
(1)Event Bus:
// event-bus.js
import Vue from 'vue';
export const EventBus = new Vue();
(2)兄弟组件A(发送数据):
<template><div><button @click="sendData">发送数据到兄弟组件</button></div>
</template><script>
import { EventBus } from './event-bus.js';export default {methods: {sendData() {EventBus.$emit('data-to-brother', '这是来自兄弟组件A的数据');}}
};
</script>
(3)兄弟组件B(接收数据):
<template><div><div>{{ dataFromBrother }}</div></div>
</template><script>
import { EventBus } from './event-bus.js';export default {data() {return {dataFromBrother: ''};},created() {EventBus.$on('data-to-brother', this.receiveData);},methods: {receiveData(data) {this.dataFromBrother = data;}},beforeDestroy() {EventBus.$off('data-to-brother', this.receiveData);}
};
</script>
3.代码讲解
这段代码是一个 Vue.js 组件的示例,它使用了 Vue 的事件总线(Event Bus)来接收来自兄弟组件的数据,并将其显示在模板中。以下是对代码的详细解释:
代码结构
- 模板部分 (
<template>):- 这是一个简单的 Vue 模板,包含一个
div元素,用于显示从兄弟组件接收到的数据。 {{ dataFromBrother }}是 Vue 的插值语法,用于动态绑定数据。
- 这是一个简单的 Vue 模板,包含一个
- 脚本部分 (
<script>):- 定义了一个 Vue 组件,包含
data、created、methods和beforeDestroy生命周期钩子。
- 定义了一个 Vue 组件,包含
代码详细解释
- 数据绑定
data() {return {dataFromBrother: ''};
}
data是 Vue 组件的选项,用于定义组件的响应式数据。dataFromBrother是一个字符串,用于存储从兄弟组件接收到的数据。
2. 事件监听
created() {EventBus.$on('data-to-brother', this.receiveData);
}
created是 Vue 的生命周期钩子,表示组件实例被创建后执行的代码。EventBus.$on是事件总线的监听方法,用于监听事件'data-to-brother'。- 当事件
'data-to-brother'被触发时,调用this.receiveData方法。
3. 数据接收
methods: {receiveData(data) {this.dataFromBrother = data;}
}
methods是 Vue 组件的选项,用于定义组件的方法。receiveData是一个方法,接收一个参数data,并将该数据赋值给dataFromBrother。
4. 事件解绑
beforeDestroy() {EventBus.$off('data-to-brother', this.receiveData);
}
beforeDestroy是 Vue 的生命周期钩子,表示组件销毁之前执行的代码。EventBus.$off是事件总线的解绑方法,用于移除事件'data-to-brother'的监听器。- 这一步非常重要,避免内存泄漏和不必要的事件触发。
事件总线(Event Bus)
事件总线是一种在 Vue 组件之间通信的方式,适用于兄弟组件之间的通信。它通过一个共享的事件中心来触发和监听事件。
事件总线的定义
在 event-bus.js 文件中,通常会这样定义事件总线:
import Vue from 'vue';
export const EventBus = new Vue();
- 这里创建了一个新的 Vue 实例作为事件总线。
使用场景
假设有一个兄弟组件,它通过事件总线发送数据:
// 兄弟组件
import { EventBus } from './event-bus.js';export default {methods: {sendData() {const dataToSend = 'Hello from brother component';EventBus.$emit('data-to-brother', dataToSend);}}
};
- 当
sendData方法被调用时,它通过事件总线触发'data-to-brother'事件,并传递数据。
总结
这段代码展示了如何使用 Vue 的事件总线在兄弟组件之间通信。通过监听和触发事件,组件可以共享数据,而不需要直接的父子关系。
四. 跨级组件传值(Provide/Inject)
-
规范:祖先组件可以使用
provide选项提供数据,而子孙组件可以使用inject选项注入这些数据。 -
代码演示:
(1)祖先组件:
<template><div><descendant-component /></div>
</template><script>
import DescendantComponent from './DescendantComponent.vue';export default {components: {DescendantComponent},provide() {return {crossLevelData: '这是跨级传递的数据'};}
};
</script>
(2)子孙组件:
<template><div>{{ crossLevelData }}</div>
</template><script>
export default {inject: ['crossLevelData']
};
</script>
- 解说:祖先组件通过
provide提供数据,子孙组件通过inject注入这些数据。这种方法适用于跨越多个层级的组件通信。
这些是在Vue CLI项目中常用的组件间属性传值的方法和规范。每种方法都有其适用场景,开发者可以根据具体需求选择最合适的传值方式。
相关文章:
vue组件中各种类型之间的传值
在Vue CLI项目中,组件间的属性传值是一个常见的需求。以下是一些常用的传值方法和规范,以及相应的代码演示和解说: 一. 父组件向子组件传值(Props) 规范:父组件通过属性(props)向子…...
公然上线传销项目,Web3 的底线已经被无限突破
作者:Techub 热点速递 撰文:Yangz,Techub News 今天早些时候,OKX 将上线 PI 的消息在圈内引起轩然大波,对于上线被板上钉钉为传销盘子的「项目」 ,Techub News 联系了 OKX 公关,但对方拒绝置评…...
GitLab CI/CD 的配置详解:从零开始使用 .gitlab-ci.yml 文件
在现代软件开发中,CI/CD(持续集成与持续部署)已成为提高开发效率和代码质量的核心实践。GitLab CI/CD 提供了强大的功能,帮助开发者自动化构建、测试和部署应用程序。而 .gitlab-ci.yml 文件是 GitLab CI/CD 配置的关键所在&#…...
C语言第18节:自定义类型——联合和枚举
1. 联合体 C语言中的联合体(Union)是一种数据结构,它允许在同一内存位置存储不同类型的数据。不同于结构体(struct),结构体的成员各自占有独立的内存空间,而联合体的所有成员共享同一块内存区域…...
Python的元组和列表的区别是什么?
1. 定义和语法形式 列表(List):列表是一种可变的序列类型,使用方括号 [] 来定义。例如:my_list [1, 2, 3] 。列表中的元素可以是不同的数据类型,并且可以包含嵌套的列表、元组等其他数据结构。元组&#x…...
解锁网络安全:穿越数字世界的防护密码
个人主页:java之路-CSDN博客(期待您的关注) 目录 网络安全:数字时代的基石 网络安全面面观 (一)定义与范畴 (二)发展历程 网络安全面临的威胁 (一)恶意软件肆虐 (二…...
利用二分法+布尔盲注、时间盲注进行sql注入
一、布尔盲注: import requestsdef binary_search_character(url, query, index, low32, high127):while low < high:mid (low high 1) // 2payload f"1 AND ASCII(SUBSTRING(({query}),{index},1)) > {mid} -- "res {"id": payloa…...
GPT-SWARM和AgentVerse的拓扑结构和交互机制
GPT-SWARM和AgentVerse的拓扑结构和交互机制 拓扑结构区别 GPT-SWARM:采用图结构,将语言智能体系统描述为可优化的计算图。图中的每个节点代表一个操作,如语言模型推理或工具使用等特定功能,边则描述了操作之间的信息流,代表智能体之间的通信渠道。多个智能体连接形成的复…...
python爬虫解决无限debugger问题
方法一 关闭定时任务 关闭断点执行代码打开断点 # 无限debugger产生原因 # 1. web开发者工具打开 # 2. js代码中有debugger # 3. js有定时处理[推荐] for(let i0;i<99999;i){window.clearInterval(i)}方法二 关闭breakpoint 方法三 修改JS代码 使用fiddler,抓…...
使用rknn进行facenet部署
文章目录 开源仓库pth转onnxnetron可视化onnx转rknnC++实现开源仓库 https://github.com/bubbliiiing/facenet-pytorch pth转onnx 修改facenet网络的forward函数代码 修改前 def forward(self, x, mode = "predict"):if mode ==...
C# 两种方案实现调用 DeepSeek API
目录 序 开发运行环境 访问API的一个通用方法 原生官网实现 申请 API key 调用实现 调用示例 腾讯云知识引擎原子调用 申请 API key 调用示例 小结 序 DeepSeek(深度求索) 最近可谓火爆的一塌糊涂,具体的介绍这里不再赘述&#x…...
Linux下的进程切换与调度
目录 1.进程的优先级 优先级是什么 Linux下优先级的具体做法 优先级的调整为什么要受限 2.Linux下的进程切换 3.Linux下进程的调度 1.进程的优先级 我们在使用计算机的时候,通常会启动多个程序,这些程序最后都会变成进程,但是我们的硬…...
图神经网络是什么,有什么实际应用
图神经网络是什么 图神经网络(Graph Neural Network,GNN)是一种专门用于处理图结构数据的神经网络,它能对图中的节点、边和整个图进行学习和推理,在社交网络分析、生物信息学、推荐系统等领域应用广泛。以下是其原理及示例说明: 图神经网络原理 节点表示学习:为图中每…...
Debezium日常分享系列之:解码逻辑解码消息内容
Debezium日常分享系列之:解码逻辑解码消息内容 示例配置选项 DecodeLogicalDecodingMessageContent SMT将PostgreSQL逻辑解码消息的二进制内容转换为结构化形式。当Debezium PostgreSQL连接器捕获逻辑解码消息时,它会将消息事件记录发送到Kafka。默认情况…...
anolis os 8.9安装jenkins
一、系统版本 # cat /etc/anolis-release Anolis OS release 8.9 二、安装 # dnf install -y epel-release # wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo # rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.…...
java8、9新特性
JAVA8 Lambda 表达式 (parameters) -> expression 或 (parameters) ->{ statements; } 提供了一种更为简洁的语法,尤其适用于函数式接口。相比于传统的匿名内部类,Lambda 表达式使得代码更为紧凑,减少了样板代码的编写。 它允许将函…...
利用kali linux 进行自动化渗透测试
本方案旨在自动化创建渗透测试全流程 一、架构 1.智能信息收集体系 class IntelligentOSINT:def __init__(self, target):self.target targetself.intelligence_sources [OSINT_Platforms,DeepWeb_Crawlers, SocialMedia_Trackers,ML_Correlation_Engine]def advanced_col…...
Java基础知识总结(四十八)--TCP传输、TCP客户端、TCP服务端
**TCP传输:**两个端点的建立连接后会有一个传输数据的通道,这通道称为流,而且是建立在网络基础上的流,称之为socket流。该流中既有读取,也有写入。 **tcp的两个端点:**一个是客户端,一个是服务…...
【python】http.server内置库构建临时文件服务
需要从linux开发机上下载一个文件到本地,约700M比较大,通过sz命令下载较慢且传输过程不稳定连续失败,后采用下面方式解决。 cd到一个目录下执行python -m http.server port,port为服务的端口号: 启动后浏览器中访问…...
如何从0开始将vscode源码编译、运行、打包桌面APP
** 网上关于此的内容很少,今天第二次的完整运行了,按照下文的顺序走不会出什么问题。最重要的就是环境的安装,否则极其容易报错,请参考我的依赖版本以及文末附上的vscode官方指南 ** 第一步:克隆 VSCode 源码 首先…...
亚冬会绽放“云端”,联通云如何点亮冰城“科技之光”?
科技云报到原创。 35年前,中国第一次承办亚运会,宣传曲《亚洲雄风》红遍大江南北,其中有一句“我们亚洲,云也手握手”。如今回看,这句话仿佛有了更深的寓意:一朵朵科技铸就的“云”,把人和人连…...
网络安全ids是什么意思
1、 简述IPS和IDS的异同点; 入侵检测系统(IDS) IDS(Intrusion Detection Systems,入侵检测系统),专业上讲就是依照一定的安全策略,对网络、系统、运行状况进行监视,尽可能…...
ASP.NET Core程序的部署
发布 不能直接把bin/Debug部署到生产环境的服务器上,性能低。应该创建网站的发布版,用【发布】功能。两种部署模式:“框架依赖”和“独立”。独立模式选择目标操作系统和CPU类型。Windows、Linux、iOS;关于龙芯。 网站的运行 在…...
优选驾考小程序
第2章 系统分析 2.1系统使用相关技术分析 2.1.1Java语言介绍 Java语言是一种分布式的简单的 开发语言,有很好的特征,在安全方面、性能方面等。非常适合在Internet环境中使用,也是目前企业级运用中最常用的一个编程语言,具有很大…...
42.水果销售系统(springbootvue的Java项目[含微信小程序])
目录 1.系统的受众说明 2.开发环境与技术 2.1 MYSQL数据库 2.2 Java语言 2.3 微信小程序技术 2.4 SpringBoot框架 2.5 B/S架构 2.6 Tomcat 介绍 2.7 HTML简介 2.8 MyEclipse开发工具 3.系统分析 3.1 可行性分析 3.1.1 技术可行性 3.1.2 经济可行性 3.1.3 操作…...
ffmpeg所有版本下载地址
地址如下:Index of /releaseshttps://ffmpeg.org/releases/...
记PasteSpider部署工具的Windows.IIS版本开发过程之草稿-效果展示(4)
如果有人给你一串JSON数据,你需要编辑他,对于有开发基础的人来说,可能会好处理下,而对于没有开发基础的人来说,那就是灾难了! 那么有没有一个东西,可以让这个编辑更顺畅呢? 贴代码案例中的DynamicForm你值得拥有!本次展示作者在本机上操作IIS的示例,如下 IIS展示 先…...
Docker 网络的配置与管理
目录 查看所有网络 查看网络详细信息 创建新的网络 删除网络 清理未使用的网络 将容器连接到网络 将容器从网络中断开 将容器端口映射到宿主机 绑定到特定 IP 地址 为容器设置自定义 DNS 查看所有网络 docker network ls 功能:列出所有 Docker 网络。 工…...
3D文档控件Aspose.3D实用教程: 在 Java 中创建 FBX 文件并无缝将圆柱体转换为网格
概述 创建FBX文件并将圆柱体转换为网格是 3D 建模和动画中的基本任务。这些过程在游戏、电影和建筑等行业中至关重要。通过使用Aspose.3D for Java ,开发人员可以高效地管理 3D 场景和对象。这个强大的 Java 3D API 简化了 3D 模型的创建和操作。它的易用性和灵活性…...
软考高级《系统架构设计师》知识点(一)
计算机硬件 校验码 码距:就单个编码A:00而言,其码距为1,因为其只需要改变一位就变成另一个编码。在两个编码中,从A码到B码转换所需要改变的位数称为码距,如A:00要转换为B:11,码距为2。一般来说,…...
