zoukankan      html  css  js  c++  java
  • EventEmitter的前端JS实现

    EventEmitter的前端JS实现

    /**
     * on(event, listener):为指定事件注册一个监听器,接受一个字符串 event 和一个回调函数。
     * emit(event, [arg1], [arg2]): 按监听器的顺序执行执行每个监听器
     * addListener(event, listener):on的同名函数(alias)
     * once(event, listener): 和on类似,但只触发一次,随后便解除事件监听
     * removeListener(event, listener): 移除指定事件的某个监听回调
     * removeAllListeners([event]):移除指定事件的所有监听回调
     * setMaxListeners(n):用于提高监听器的默认限制的数量。(默认10监听回调个产生警告)
     * listeners(event): 返回指定事件的监听器数组。
     */
    var EventEmitter = {
      maxListeners: 10,
      events: {},
      on: function(event, listener) {
        if (!this.events[event]) {
          this.events[event] = [listener]
          return
        }
        this.events[event].push(listener)
        if (this.events[event].length > this.maxListeners) {
          console.warn(event + '超出' + this.maxListeners + '监听')
        }
      },
      emit: function(event) {
        var params = [].slice.call(arguments)
        params.shift()
        if (!this.events[event]) {
          return
        }
        var originLen = this.listeners(event).length
        for (var i = 0 ; i < this.events[event].length; i++) {
          this.events[event][i].apply(null, params)
          if (originLen > this.events[event].length) {
            // 解决 once执行removeListener函数的时候长度问题导致的event漏执行问题
            i--
            originLen--
          }
        }
      },
      addListener: function(event, listener) {
        return this.on(event, listener)
      },
      once: function(event, listener) {
        var self = this
        function fn() {
          var args = [].slice.call(arguments)
          listener.apply(null, args)
          self.removeListener(event, fn)
        }
        this.on(event, fn)
      },
      removeListener: function(event, listener) {
        if (!this.events[event]) {
          return
        }
        var index = this.events[event].indexOf(listener)
        if (index >= 0) {
          this.events[event].splice(index, 1)
        }
      },
      removeAllListeners: function(event) {
        if (event) {
          delete this.events[event]
        } else {
          this.events = {}
        }
      },
      setMaxListeners: function(n) {
        this.maxListeners = n
      },
      listeners: function(event) {
        if (this.events[event]) {
          return this.events[event]
        } else {
          return []
        }
      }
    }
    
    EventEmitter.once('event', function() {
      console.log('仅仅触发一次')
    })
    
    EventEmitter.on('event', function(arg1) {
      console.log('一个参数', arg1)
    })
    
    EventEmitter.on('event', function(arg1, arg2) {
      console.log('二个参数', arg1, arg2)
    })
    
    EventEmitter.on('event', function(arg1, arg2, arg3) {
      console.log('三个参数', arg1, arg2, arg3)
    })
    
    EventEmitter.emit('event', 1, 2, 3)
    EventEmitter.emit('event', 1, 2, 3)
    
    // 打印:
    // 仅仅触发一次
    // 一个参数 1
    // 二个参数 1 2
    // 三个参数 1 2 3
    // 一个参数 1
    // 二个参数 1 2
    // 三个参数 1 2 3
    
  • 相关阅读:
    java中的静态代理、jdk动态代理和cglib动态代理
    第三方支付熟悉
    C#进制转换
    维翔主机asp主机使用遇到的问题及解决方案总结
    windows上JSP开发环境全搭建
    文件校验工具的开发及问题
    C#加密算法总结
    WampServer搭建php环境可能遇到的问题
    分分钟搭建自己的微信聊天机器人
    KindEditor编辑器在ASP.NET中的使用
  • 原文地址:https://www.cnblogs.com/chenfengami/p/14676994.html
Copyright © 2011-2022 走看看