js观察者模式学习

Posted 杜培东

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js观察者模式学习相关的知识,希望对你有一定的参考价值。

      function Events(){
            var obj = {};
            this.on=function(key,fn){
               var stack;
               stack = obj[key] || (obj[key] =[]);
               
               return stack.push(fn);
            }
            this.off=function(key){

                var stack;
                return (stack=obj[key]) != null ? stack.length=0 : void 0;//此处stack.length=0不等同于stack=[],如果设置stack=[],并不能作用于object[key]
            }
            this.once=function(key,fn){
                this.off(key);
                return this.on(key,fn);
            }
            this.trigger=function(){
                var key,stack,i;
                key = [].shift.call(arguments);
                stack = obj[key]||(obj[key] = []);
                for(i=0;i<stack.length;i++){
                    stack[i].apply(this,arguments);
                }
            }
        }
        var events = new Events();
        events.on("play",function(data){
            console.log(data.name)
        });
        events.on("play",function(data){
            console.log(data.age)
        });
        events.trigger("play",{name:"dpd",age:13})

 

以上是关于js观察者模式学习的主要内容,如果未能解决你的问题,请参考以下文章

设计模式 行为型模式 -- 观察者模式(发布-订阅(Publish/Subscribe)模式)

js设计模式之实现观察者模式实例代码

js中的观察者模式

JS实现Observable观察者模式

js设计模式-观察者模式来模拟vue的双向数据绑定

js 高阶函数 发布订阅观察者模式 手撕promise