069:vue中EventBus的使用方法(图文示例)

2024-02-03 18:12

本文主要是介绍069:vue中EventBus的使用方法(图文示例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

第069个

查看专栏目录: VUE ------ element UI


本文章目录

    • 示例背景
    • 示例效果图
    • 示例源代码
      • 父组件:
      • 子组件A:
      • 子组件B:
      • eventbus/index.js:
    • EventBus的基本使用方法:

示例背景

在Vue中,使用EventBus可以实现组件间的通信,如何使用EventBus? 都需要做哪些配置呢?他的注意事项是什么呢?请参考以下示例及使用步骤。

示例效果图

在这里插入图片描述

示例源代码

父组件:

/*
* @Author: 大剑师兰特(xiaozhuanlan),还是大剑师兰特(CSDN)
* @此源代码版权归大剑师兰特所有,可供学习或商业项目中借鉴,未经授权,不得重复地发表到博客、论坛,问答,git等公共空间或网站中。
* @Email: 2909222303@qq.com
* @weixin: gis-dajianshi
* @First published in CSDN
* @First published time: 2024-02-03
*/<template><div class="djs-box"><div class="topBox"><h3>vue使用EventBus的图文示例 </h3><div>大剑师兰特, 还是大剑师兰特,gis-dajianshi</div></div><div class="dajianshi"><div class="item"><ComA></ComA></div><div class="item"><ComB></ComB></div></div></div>
</template><script>import ComA from '../components/eventbus/demo-A.vue';import ComB from '../components/eventbus/demo-B.vue'export default {data() {return {}},components:{ComA,ComB},}
</script>
<style scoped>.djs-box {width: 1000px;height: 650px;margin: 50px auto;border: 1px solid peru;}.topBox {margin: 0 auto 0px;padding: 10px 0 20px;background: peru;color: #fff;}.dajianshi {width: 98%;height: 480px;margin: 5px auto 0;display: flex;justify-content: space-between;}.item{width: 48%;height: 480px;margin-top: 20px;text-align: center;border: 1px solid #583;		}
</style>

子组件A:

<template><div><h2> 组件A</h2><el-button @click="sendMessage">发送消息给B</el-button><h4>B获取的消息:</h4><div style="color: blue;">{{message}}</div></div>
</template><script>import {EventBus} from '@/eventbus/index.js';export default {data() {return {message: ''};},mounted() {EventBus.$on('messageB', (msg) => {this.message = msg;});},methods: {sendMessage() {EventBus.$emit('messageA', 'Hello from Component A');}}}
</script>

子组件B:

<template><div><h2> 组件B</h2><el-button @click="sendMessage">发送消息给A</el-button><h4>A获取的消息:</h4><div style="color: red;">{{ message }}</div></div>
</template><script>import {EventBus} from '@/eventbus/index.js';export default {data() {return {message: ''};},mounted() {EventBus.$on('messageA', (msg) => {this.message = msg;});},methods: {sendMessage() {EventBus.$emit('messageB', 'Hello from Component B');}}}
</script>

eventbus/index.js:

import Vue from ‘vue’;
export const EventBus = new Vue();

EventBus的基本使用方法:

  • List item初始化EventBus:首先需要创建一个EventBus实例。可以通过创建一个新的.js文件(如event-bus.js),然后导入Vue并实例化一个新的Vue对象来创建EventBus。或者,可以直接在项目的main.js文件中初始化EventBus。
  • 发送事件:要向EventBus发送事件,可以使用 e m i t 方 法 。 例 如 , t h i s . emit方法。例如,this. emitthis.EventBus.$emit(‘eventName’, payload),其中eventName是事件名,payload是要传递的参数。
  • 监听事件:要在组件中监听EventBus上的事件,可以使用 o n 方 法 。 例 如 , t h i s . on方法。例如,this. onthis.EventBus.$on(‘eventName’, callback),其中eventName是事件名,callback是处理事件的函数。
  • 移除监听:如果需要在组件销毁时移除事件监听,可以使用 o f f 方 法 。 例 如 , t h i s . off方法。例如,this. offthis.EventBus.$off(‘eventName’, callback)。
  • 注意事项:虽然EventBus提供了一种简单的方式来实现组件间通信,但过度使用可能会导致代码难以维护。因此,对于更复杂的应用,建议使用Vuex作为状态管理解决方案。

总的来说,通过以上步骤,可以在Vue项目中使用EventBus来实现不同组件之间的通信。

这篇关于069:vue中EventBus的使用方法(图文示例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/674962

相关文章

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd