vue中EventBus的使用教程详解

 更新时间:2024年02月03日 09:07:28   作者:还是大剑师兰特  
在Vue中,使用EventBus可以实现组件间的通信,如何使用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.emit方法。例如,this.EventBus.$emit(‘eventName’, payload),其中eventName是事件名,payload是要传递的参数。

监听事件:要在组件中监听EventBus上的事件,可以使用o n 方 法 。 例 如 , t h i s . on方法。例如,this.on方法。例如,this.EventBus.$on(‘eventName’, callback),其中eventName是事件名,callback是处理事件的函数。

监听:如果需要在组件销毁时移除事件监听,可以使用o f f 方 法 。 例 如 , t h i s . off方法。例如,this.off方法。例如,this.EventBus.$off(‘eventName’, callback)。

注意事项:虽然EventBus提供了一种简单的方式来实现组件间通信,但过度使用可能会导致代码难以维护。因此,对于更复杂的应用,建议使用Vuex作为状态管理解决方案。

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

到此这篇关于vue中EventBus的使用教程详解的文章就介绍到这了,更多相关vue EventBus内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue使用axios post方式将表单中的数据以json格式提交给后端接收操作实例

    Vue使用axios post方式将表单中的数据以json格式提交给后端接收操作实例

    这篇文章主要介绍了Vue使用axios post方式将表单中的数据以json格式提交给后端接收操作,结合实例形式分析了vue基于axios库post传送表单json格式数据相关操作实现技巧与注意事项,需要的朋友可以参考下
    2023-06-06
  • 如何利用vue实现css过渡和动画

    如何利用vue实现css过渡和动画

    过渡Vue在插入、更新或者移除 DOM 时,提供多种不同方式的应用过渡效果这篇文章主要给大家介绍了关于如何利用vue实现css过渡和动画的相关资料,需要的朋友可以参考下
    2021-11-11
  • vue中组件的name属性含义和用法示例

    vue中组件的name属性含义和用法示例

    组件是有name属性的,匹配的就是组件的name,下面这篇文章主要给大家介绍了关于vue中组件的name属性含义和用法的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • v-model中如何使用过滤器

    v-model中如何使用过滤器

    这篇文章主要介绍了v-model中如何使用过滤器问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • Vue3使用Vue Router实现前端路由控制

    Vue3使用Vue Router实现前端路由控制

    在现代Web应用中,前端路由控制是非常重要的一部分,它可以帮助我们将不同的页面内容展示给用户,同时保持用户在浏览不同页面时的连贯性,本文将介绍如何使用Vue Router来实现前端路由控制,需要的朋友可以参考下
    2024-10-10
  • Vue3中使用jsx/tsx的教程详解

    Vue3中使用jsx/tsx的教程详解

    这篇文章主要为大家详细介绍了如何在Vue3中使用jsx/tsx的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,需要的小伙伴可以了解下
    2024-02-02
  • vue关于this.$refs.tabs.refreshs()刷新组件方式

    vue关于this.$refs.tabs.refreshs()刷新组件方式

    这篇文章主要介绍了vue关于this.$refs.tabs.refreshs()刷新组件方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Vue+penlayers实现多边形绘制及展示

    Vue+penlayers实现多边形绘制及展示

    这篇文章主要为大家详细介绍了Vue+penlayers实现多边形绘制及展示,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • vue实现子路由调用父路由的方法

    vue实现子路由调用父路由的方法

    这篇文章主要介绍了vue实现子路由调用父路由的方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • vue中el-table两个表尾合计行联动同步滚动条实例代码

    vue中el-table两个表尾合计行联动同步滚动条实例代码

    项目开发中遇到一个比较两个form差异的需求,但当item过多就需要滚动条,下面这篇文章主要给大家介绍了关于vue中el-table两个表尾合计行联动同步滚动条的相关资料,需要的朋友可以参考下
    2022-05-05

最新评论