为了账号安全,请及时绑定邮箱和手机立即绑定

js的事件订阅

标签:
JavaScript

学习了https://blog.csdn.net/Mandyucan/article/details/80820139这位兄弟的博客。
这段时间用到事件订阅的例子不少于是就来学习了一下,事件订阅在js总的webview;node的事件发送和接收;vue的组件间的事件通信以及事件巴士等是很常用的。

var eventCenter = {
      sub: function(name, callback) {
        this.argus = this.argus || {};//已经有事件用已经有的this.argus
        this.argus[name] = this.argus[name] || [];
        this.argus[name].push(callback);//对应添加的事件名已经有了就在加到该事件的数组中
      },
      pub: function(name, obj) {
        var args = Array.prototype.slice.call(arguments, 0);//arguments(Object)是传入的参数这里取到第一个;也可以直接通过函数传入参数的形式
        var name = args.shift();
        if (!this.argus || !this.argus[name]) {//没有传入参数就不往下执行
          return this;
        }
        for (var i = 0; i < this.argus[name].length; i++) {
          this.argus[name][i].apply(this, args);//触发订阅事件的回调事件,apply(this, args)是为了拿到传入的参数;this.argus[name][i](args)也可以实现
        }
      }
    };
    eventCenter.sub("a", function(res) {//添加事件
      console.log(12345678,res)
    });
    eventCenter.pub("a", {name: 1});//触发订阅事件发送参数

这里有用到call和apply这两个方法在很多封装的地方很常用到。
第一个参数是改变this的指向了第二个参数是传入到这个方法的参数并执行这个方法。
call能传入多个参数;apply要传入数组。


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消