JS设计模式的一点感悟

2018-02-21  本文已影响48人  风之化身呀

JS设计模式读后感

最近在看《Javascript设计模式》这本书,此书并没有空谈设计模式,而是每种模式都结合了具体的业务,这些具体的业务对于前端开发者也是经常遇到的,所以很容易产生共鸣。(全书大概有38种设计模式,有的模式用的少,本文仅记录模式的核心思想)

创建型设计模式(6种)

// 类实现,可复用父类公用方法
var popFactory=function(name){
    switch(name){
        case 'alert':
            return new LoginAlert();
        case 'confirm':
            return new LoginConfirm();
        case 'prompt':
            return new LoginPrompt();
    }
}

// 对象实现,公用逻辑
function createPop(type,text){
    var o=new Object();
    o.content=text;
    o.show=function(){};
    if(type=='alert'){
        // 差异部分
    }
    if(type=='prompt'){
        //差异部分
    }
    if(type=='confirm'){
        // 差异部分
    }
    return o;
}
//工厂模式里有个安全模式
function A(){
    if(this instanceof A)
        return this;
    else
        return new A();
}
// 抽象工厂里有个抽象类的模拟实现(JS本身无抽象类,通过抛出Error模拟实现)
var Car=function(){}
Car.prototype={
    getPrice:function(){
        return new Error('抽象方法不能调用')
    }
}
MoTuoCar=function(){}
MoTuoCar.prototype=new Car();
MoTuoCar.prototype.constructor=MoTuoCar;
var a=new MoTuoCar();
a.getPrice() //报错

结构型设计模式(7种)

行为型设计模式(11种)

技巧型设计模式(8种)

架构型设计模式(6种)

模块化开发的思想:将复杂的系统分解成高内聚低耦合的模块,每位工程师独立的开发自己的模块,从而使复杂的系统可控、可维护、可扩展。

上一篇 下一篇

猜你喜欢

热点阅读