Skip to content
Menu
Yuuk的博客
  • 首页
  • 前端技术
    • JavaScript
    • HTML & CSS
  • SEO
  • 设计
    • 素材分享
    • 设计教程
  • 随笔
Yuuk的博客

发布订阅模式小练习-自定义事件

Posted on 2018年6月11日 by yuuk
function Event() {
    this._events = {};
}
Event.prototype.on = function(eventName, callback) {
    if (this._events[eventName]) {
        // 存放多个相同事件
        this._events[eventName].push(callback);
    } else {
        this._events[eventName] = [callback];
    }
}
Event.prototype.emit = function(eventName) {
    var args = Array.prototype.slice.call(arguments).splice(1); // 获取第一个参数外的人所有参数
    // 调用事件
    if (this._events[eventName]) {
        this._events[eventName].forEach(fn => fn(args));
    }
}

var ev = new Event();

ev.on('eat', function(data) {
    console.log('eat事件被触发');
    console.log(data);
});

ev.emit('eat', 'rice');
打赏赞(2)分享

发表回复 取消回复

您的邮箱地址不会被公开。 必填项已用 * 标注

搜索

近期文章

  • 宝塔面板中使用docker部署nodejs应用
  • 如何将docker镜像上传到阿里云
  • React Native 报错 No bundle URL present 解决方法
  • axios 给每一个请求添加耗时统计
  • css filter属性导致fixed失效

标签

addEventListener ajax ajax跨域 chatAt css居中 DNS缓存 docker gulp ie7 json jsonp margin memcache mysql nodejs ps技巧 typescript void vpn vuejs wampserver webpack win10 XMLHttpRequest z-index 事件冒泡 事件绑定 内容发布时间 图片加载 大写 字符串 封装ajax 广告屏蔽 批量修改图层名称 水平垂直居中 注册码 特殊符号 百度 空元素 站长平台 网页快照 负边界 递减 随机数 首字母

友情链接

  • 蔡甸新闻网
©2025 Yuuk的博客 | 鄂ICP备13014750号-9