js自定义事件

自定义事件:js的自定义事件是用的观察者的设计模式,有主体和观察者两部分组成,主体对象不在乎是否有观察者依然可以运行,观察者对主体动作观察,当主体发布事件后,观察者捕获事件后运行代码(自我感觉,是主体通知注册的观察者,告诉观察者事件的发生)。下面以一个简单的小例子来创建一个自定义事件

<script>
    (function(w){
        function MyEventTest(){  //主体对象
            this.mapHandlers = {};
            this.name = "";
        }
        //在原型链上创建,避免每次new再次创建
        MyEventTest.prototype = { 
            constructor : MyEventTest,
            
            addListener : function(type,handler){
               this.mapHandlers[type] = handler;
            },
            fire : function(event){
                if(!event.target){
                    event.target = this; //把主体对象绑定到event.target
                }
                this.mapHandlers[event.type](event);
            },
            setName : function(value){
                if(typeof value == 'string'){
                    this.name = value;
                    if(this.mapHandlers['afterSetName']){
                        this.fire({type:'afterSetName',name:value});
                    }
                }
            }
        };
        //绑定到window
        w.jQuery = w.$ = MyEventTest;
    })(window);
    
    var target  = new jQuery();
    //注册监听事件
    target.addListener('afterSetName',function(event){
        alert(event.name);
    });
    target.setName("小强");//setName会触发注册的事件
</script>


转载于:https://my.oschina.net/u/1450816/blog/273896

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值