JavaScript设计模式----单例模式

这篇博客探讨了JavaScript中的单例模式,包括其特点和定义,对比了传统面向对象语言的实现方式,如使用闭包和透明单例模式。文章通过具体的代码示例,分析了惰性单例和通用单例模式,并强调了单例模式在JavaScript中的独特应用,总结了单例模式的实用性,特别是惰性单例在资源管理上的优势。
摘要由CSDN通过智能技术生成

声明:这个系列为阅读《JavaScript设计模式与开发实践》 —-曾探@著一书的读书笔记

1.单例模式的特点和定义

保证一个类仅有一个实例,并且提供一个访问它的全局访问点。

2.传统面向对象语言的单例模式

2.1传统语言描述的单例模式JavaScript实现
var Singleton = function(name) {
   
    this.name = name;
    this.instance = null;
};

Singleton.prototype.getName = function() {
   
    alert(this.name);
};

Singleton.getInstance = function(name) {
   
    if (!this.instance) {
        this.instance = new Singleton(name);
    }

    return this.instance;
};

var a = Singleton.getInstance('seven1');
var b = Singleton.getInstance('seven2');

或者使用闭包的形式创建单例模式,同时符合惰性单例的特性

var Singleton = function(name) {
   
    this.name = name;
};

Singleton.prototype.getName = function() {
   
    alert(this.name);
};

//利用闭包的特性创建单例,同时符合惰性单例的特性
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值