• JavaScript常用设计模式


    单例模式:确保类只能被实例化一次。

    var obj = {}
    2、函数返回值
    var func = function () {return {}}
    var obj = func();
    3、构造函数初始化
    var obj = (function () {return {}})()
    

    装饰者模式:装饰者用用于包装同接口的对象。

    var obj = obj || {}
    obj.set = function(){}
    obj.get = function(){}
    obj.……= function(){}
    

    模块模式:该模式使用闭包封装私有状态和组织。

    var module = (function(obj){})({});
    

    观察者模式:它定义了一种一对多的关系,让多个观察者对象同时监听某一个主题对象。

    function func() {}
    func.prototype.set = function(opt){}
    func.prototype.get = function(opt){}
    var obj = new func();
    obj.set({});
    obj.get({});
    

    构造函数模式:自定义自己的构造函数,然后在里面声明自定义类型对象的属性或方法。 

    1、构造函数
    function func(name,age){
    	this.id = 0;
    	//code……
    }
    func.prototype.pro = function(){}
    2、构造函数强制实例化
    function func(title) {
        if (!(this instanceof func)) {
            return new func(title);
        }
        this.title = title;
    }
    func.prototype.get = function () { return this.title; }
    console.log(obj.get());
    

    工厂模式:工厂模式就好比现实生活中的工厂可以产生大量相似的产品。

    function func(opt){
    	var obj = {
    		id:0,
    		title:''
    	}
    	return $.extend(obj,opt);
    }
    var f1 = func({id:1,title:'标题1'});
    var f2 = func({id:2,title:'标题2'});
    

    对象创建模式:对象中创建对象

    模式1:命名空间(namespace)
    var obj = obj || {};
    obj.app = obj.app || {};
    obj.app.ios = obj.app.ios || {};
    obj.app.android = obj.app.android || {};
    模式2:通过自执行函数创建对象
    var obj;
    (function () {
    	obj = {}
    })
    模式3:链模式
    var obj = {
    	func1: function () {return this;},
    	func2: function () {return this;},
    	……: function () {return this;}
    }
    // 链方法调用
    obj.func1().func2().……();
    模式4:函数语法糖
    函数语法糖是为一个对象快速添加方法(函数)的扩展,这个主要是利用prototype的特性
    if (typeof Function.prototype.method !== "function") {
        Function.prototype.method = function (name, implementation) {
            this.prototype[name] = implementation;
            return this;
        };
    }
    var func = function (name) {
        this.name = name;
    }.method('set', function (name) {
        this.name = name;           
    }).method('get', function () {
        return this.name;
    });
    var a = new func('a');
    a.set('b');
    console.log(a.get());
    

    沙盒模式

  • 相关阅读:
    PB中的Grid视图
    MVC加jquery的无刷新列表分页摘要
    Quartz.Net 1.30的一些设置说明
    将Excel的数据库字典导到PDM中
    HubbleDotNet使用备忘
    EntLib5.0 日志应用程序块(logging) 使用与配置
    生成随机密码
    网站整合QQ登录
    PB代码参考段
    SQL查询之 Pivot 详解
  • 原文地址:https://www.cnblogs.com/sntetwt/p/8726324.html
Copyright © 2020-2023  润新知