Javascript实现Vue跨组件通信的方法详解

 更新时间:2022年03月10日 14:16:20   作者:_雪菜肉丝面_  
这篇文章主要为大家详细介绍了Vue的跨组件通信,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

概述

我们都知道。

xxx.$on可以订阅一个消息。

xxx.$emit可以发布一个消息。

xxx.$off可以取消订阅一个消息。

思路要清晰

这个过程涉及到的几个概念。

订阅过程:

消息,肯定要区分,来个name。

消息也要有事做,来个handler。

一堆消息,要有地方放,来个arr。

订阅时,交代叫什么name,干什么handler。

发布过程:

发布时,交代叫什么,来个name。

发布也可能有一些参数,来个param。

发布时,交代叫什么name,传递参数param。

取消订阅过程:

取消订阅,肯定要知道名字,来个name。

取消订阅时,交代要取消的name。

实现要迅猛

代码不多

class EventBus {
	constructor() {
		this.arr = [];
	}
	on = (name, fn) => {
		let filter = this.arr.filter(v => v.name === name);
		if (filter.length === 0) {
			this.arr.push({
				name, fn
			})
		}
	}
	emit = (name, param) => {
		let filter = this.arr.filter(v => v.name === name);
		if (filter.length === 1) {
			filter[0].fn(param);
		}
	}
	off = (name) => {
		this.arr = this.arr.filter(v => v.name !== name);
	}
}

构造:初始化事件数组。

实例的on:查重,如果重复了就啥都不干。没重复就push。

实例的emit:查重,如果有这事件就调用。

实例的off:筛选赋值。

测试效果

代码不多。

let bus = new EventBus();
bus.on('say', (msg) => {
	console.log(msg);
});
let i = 0;
let timer = setInterval(() => {
	if (i >= 30) {
		bus.off('say');
		clearInterval(timer);
		return;
	}
	bus.emit('say', "你好,世界!" + i++)
}, 1000);

新建一个消息中心。

订阅一个事件。

计时器,每隔一秒发布该消息。

30下后,取消订阅。

运行结果:

在这里插入图片描述

30秒后:

在这里插入图片描述

查看是否取消成功:

在这里插入图片描述

成功!

优化

使用ES6的Map代替数组,效率更好。

class EventBus {
	map = new Map();
	on = (name, handler) => {
		if (!this.map.has(name)) {
			this.map.set(name, handler);
		}
	}
	emit = (name, param) => {
		let handler = this.map.get(name);
		if (handler !== null) {
			handler(param);
		}
	}
	off = (name) => {
		this.map.delete(name);
	}
}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容! 

相关文章

  • 浅谈jQuery中setInterval()方法

    浅谈jQuery中setInterval()方法

    这篇文章主要介绍了浅谈jQuery中setInterval()方法,十分的简单实用,有需要的小伙伴可以参考下。
    2015-07-07
  • 用Fundebug插件记录网络请求异常的方法

    用Fundebug插件记录网络请求异常的方法

    这篇文章主要介绍了用Fundebug插件记录网络请求异常的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • JavaScript实现拖拽效果

    JavaScript实现拖拽效果

    这篇文章主要为大家详细介绍了JavaScript实现拖拽效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • JavaScript数字精度丢失问题的解决方案

    JavaScript数字精度丢失问题的解决方案

    JavaScript使用64位浮点数表示数字(基于IEEE 754标准),这导致某些十进制数字在计算过程中出现精度丢失,所以本文给大家介绍了JavaScript数字精度丢失问题的解决方案,需要的朋友可以参考下
    2024-10-10
  • yahoo 页面的标签效果

    yahoo 页面的标签效果

    yahoo 页面的标签效果...
    2006-10-10
  • 微信小程序实现一张或多张图片上传(云开发)

    微信小程序实现一张或多张图片上传(云开发)

    这篇文章主要介绍了微信小程序实现一张或多张图片上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • 移动适配的几种方案(三种方案)

    移动适配的几种方案(三种方案)

    本文给大家总结了三种移动适配方案,具体哪三种感兴趣的朋友可以通过本文详细学习下
    2016-11-11
  • 小程序登录之支付宝授权的实现示例

    小程序登录之支付宝授权的实现示例

    这篇文章主要介绍了小程序登录之支付宝授权的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • JavaScript中的几种继承方法示例

    JavaScript中的几种继承方法示例

    这篇文章主要给大家介绍了关于JavaScript中的几种继承方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • JS实现json数组排序操作实例分析

    JS实现json数组排序操作实例分析

    这篇文章主要介绍了JS实现json数组排序操作,结合实例形式分析了javascript针对json数组的遍历、排序简单操作技巧,需要的朋友可以参考下
    2019-10-10

最新评论