美文网首页
单例模式

单例模式

作者: helloyoucan | 来源:发表于2019-05-05 12:17 被阅读0次

单例模式:又称单体模式,是只允许实例化一次的对象类。有时候也用一个对象来规划一个明明空间,并管理对象上的属性和方法

需求1:新闻列表中做鼠标滑动特效

function g(id){ return document.getElementById(id) }
function css(id,key,value){
    //简单样式属性设置
    g(id).style[key] = value
}
function attr(id,key,value){ g(id)[key] = value }
function html(id,vale){ g(id).innerHTML = value }
function on(id,type,fn){ g(id)['on'+type] = fn }

问题:在全局中添加过多变量,容器引起冲突
优化1:命名空间

const Can = {
    g(id){},
    css(id,key,value){
        //通过当前对象this来使用g方法
        this.g(id).style[key] = value
    },
    //...
}

创建一个小型代码库

const A = {
    Util:{
        method1(){},
        method2(){},
        method3(){},
        //...
    },
    Tool:{
        method1(){},
        //...
    },
    Ajax:{
        //...
    },
    //...
}
A.Util.method1()
A.Tool.method1()

静态变量:函数内部定以能访问的变量,并定以一个特权方法访问

const Conf = (()=>{
    //私有变量
    const conf = {
        MAX_NUM:100,
        MIN_NUM:1,
        COUNT:1000
    }
    // 返回取值器对象
    return {
        // 取值器方法
        get(name){
            return conf[name]?conf[name]:null
        }
    }
})()
// 使用
const count = Conf('COUNT')
console.log(count) // 1000

惰性单例:延迟创建单例对象

const LazySingle = (()=>{
    //单例实例引用
    let _instance = null
    //单例
    function Single(){
        //这里定以私有属性和方法
        return {
            publicMethod(){},
            publicProperty:'1.0'
        }
    }
    // 获取单例实例对象接口
    return function(){
        //如果对象为创建则创建对象
        if(!_instance){
            _instance = Single()
        }
        //返回单例
        return _instance
    }
})()

相关文章

  • 【设计模式】单例模式

    单例模式 常用单例模式: 懒汉单例模式: 静态内部类单例模式: Android Application 中使用单例模式:

  • Android设计模式总结

    单例模式:饿汉单例模式://饿汉单例模式 懒汉单例模式: Double CheckLock(DCL)实现单例 Bu...

  • 2018-04-08php实战设计模式

    一、单例模式 单例模式是最经典的设计模式之一,到底什么是单例?单例模式适用场景是什么?单例模式如何设计?php中单...

  • 设计模式之单例模式详解

    设计模式之单例模式详解 单例模式写法大全,也许有你不知道的写法 导航 引言 什么是单例? 单例模式作用 单例模式的...

  • Telegram开源项目之单例模式

    NotificationCenter的单例模式 NotificationCenter的单例模式分析 这种单例模式是...

  • 单例模式Java篇

    单例设计模式- 饿汉式 单例设计模式 - 懒汉式 单例设计模式 - 懒汉式 - 多线程并发 单例设计模式 - 懒汉...

  • IOS单例模式的底层原理

    单例介绍 本文源码下载地址 1.什么是单例 说到单例首先要提到单例模式,因为单例模式是单例存在的目的 单例模式是一...

  • 单例

    iOS单例模式iOS之单例模式初探iOS单例详解

  • 单例模式

    单例模式1 单例模式2

  • java的单例模式

    饿汉单例模式 懒汉单例模式

网友评论

      本文标题:单例模式

      本文链接:https://www.haomeiwen.com/subject/wdxcoqtx.html