码迷,mamicode.com
首页 > 其他好文 > 详细

设计模式

时间:2018-05-22 19:49:17      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:nbsp   实现   return   通过   mon   相同   代码   创建   push   

 惰性函数(减少浏览器无用的判断 提高性能)

function getStyle(obj,attr){
    if(obj.currentStyle){
        getStyle = function(obj,attr){
            return obj.currentStyle[attr];
        }
    }else{
        getStyle = function(obj,attr){
            return getComputedStyle(obj,false)[attr];
        }
    }
    return getStyle(obj,attr);
}

 

如果在某一条件下重复执行那串相同的代码可以用惰性函数

 

单例模式(单例模式是一种简单但非常实用的模式,特别是惰性单例技术,在合适的时候才创建对像,并且只创建唯一的一个。更奇妙的是,创建对象和管理单例的职责被分布在两个不同的方法中,这两个方法组合起来才具有单例模式的威力。

通过闭包实现单例模式同时具备惰性
var fn=(function(){
    var div
    return function(){
        if(!div){    
        div=document.createElement("div")
    }else{
        fn=function(){
            return div  还可以是一个对象
        }
    }}
})()
var p1=fn()
var p2=fn()
console.log(fn)

代理模式(代理模式(有2个对象  第二个对象想调用第一个对象里面的东西从空间里面取出))

function 我(){

}
我.prototype={
    吃饭:function(){
        console.log(‘我正在吃饭‘)
    },
    睡觉:function(){
        console.log(‘我正在睡觉‘)
    },
    学习:function(){
        console.log(‘我在学习‘)
    }
}
function 你(){
    this.你=new 我()
}
你.prototype={
    帮忙吃饭:function(money){
        if(money>100){
            this.你.吃饭()
        }
    },
    帮忙睡觉:function(money){
        if(money>200){
            this.你.睡觉()
        }
    },
    帮忙学习:function(money){
        if(money>300){
            this.你.学习()
        }
    }
}
var 帮你=new 你()
帮你.帮忙吃饭(300)

 

发布订阅模式

有2个对象服务端和客户端
如下:
  客户端:QQ 号 具有订阅功能
  服务端:1.将客户端加进一个数组内保存起来。
      2.通过循环向他们发送消息。

function QQ(qq) {
        this.qq=qq
        this.订阅=function(msg){
            console.log(this.qq+‘收到消息‘+msg)
        }
    }
    function Email(){
        this.订阅者=[]
    }
    Email.prototype={
        添加订阅者:function(p){
            this.订阅者.push(p)
        },
        信息:function(msg){
            return "今天是XX活动,赶快上线领取终极大礼包"
        },
        通知:function(){
            for(var i in this.订阅者){
                this.订阅者[i].订阅(this.信息())
            }
        }
    }
    var email=new Email()
    email.添加订阅者(new QQ(132321))
    email.添加订阅者(new QQ(21421))
    email.添加订阅者(new QQ(214214))
    email.通知()

 

设计模式

标签:nbsp   实现   return   通过   mon   相同   代码   创建   push   

原文地址:https://www.cnblogs.com/lianqing/p/9073556.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!