ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

手动封装on,emit,off

2019-04-19 08:52:39  阅读:279  来源: 互联网

标签:封装 EventList return eventName callback off emit


 

on 绑定

emit 触发

off 解绑


//存放事件
eventList = {
key:val
handle:[]
}

 

1对多
on(eventName,callback);
handle:-------N多个
1、判断事件名称是否存在

2、如果存在的情况下将cb存放在eventName这个数组当中

3、如果不存在创建key值为eventName val值为数组

 

1对多
emit(eventName,params);

当调用emit的时候获取到eventName这的值,对值判断,如果值不存在直接return
如果存在遍历这个值全局进行调用,然后将params传入这些函数

 


off(eventName,[callback])
当调用off的时候获取到eventName这的值,对值判断,如果值不存在直接return
如果存在判断callback是否存在 如果存在删除指定的函数
如果不存在将当前数组清空


*/

const EventList = {

}


const on = function(eventName,callback){
if(!EventList[eventName]){
EventList[eventName] = [];
}

EventList[eventName].push(callback);
}


const emit = function(eventName,params){
if(!EventList[eventName])return;

EventList[eventName].map((cb)=>{
cb(params)
})
}


const off = function(eventName,callback){
if(!EventList[eventName])return;

if(callback){
let index = EventList[eventName].indexOf(callback);
EventList[eventName].splice(index,1);
}else{
EventList[eventName] = [];
}
}

将其暴露出去方便引用

export default {
$on:on,
$emit:emit,
$off:off
}

标签:封装,EventList,return,eventName,callback,off,emit
来源: https://www.cnblogs.com/aixuexi-504682107/p/10733779.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有