单例模式

本文详细介绍了JavaScript中的单例模式,包括基本实现、代理单例和惰性单例。通过示例展示了如何确保类只创建一个实例并提供全局访问点。此外,还探讨了单例模式在实际场景中的应用,如页面元素创建和iframe管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单例模式只会创建一个实例,且仅有一个实例,并提供一个访问它的全局访问点

理解单例模式

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

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

Singleton.getInstance=(function(){
    var instance=null;
    return function(name){
        if(!instance){
          instance=new Singleton(name);
        }
        return instance;
    }
})()

var a = Singleton.getInstance("aa");
var b = Singleton.getInstance("bbb");
console.log(a===b); //true

代理单例

var CreateDiv=function(html){
    this.html=html;
    this.init();
 }
 
 CreateDiv.prototype.init=function(){
     var div=document.createElement('div');
     div.innerHTML=this.html;
     document.body.appendChild(div);
 }
 
 var ProxySingletonCreateDiv=(function(){
     var instance;
     return function(html){
         if(!instance){
             instance=new CreateDiv(html);
         }
         return instance;
     }
 })()
 
 var a=new ProxySingletonCreateDiv('aa');
 var b=new ProxySingletonCreateDiv('bb');
 console.log(a===b);  //true

惰性单例,需要的时候才创建实例

 var getSingle = function(fn){
     var result;
     return function(){
         return result || (result=fn.apply(this,arguments));
     };
 };
 
 var createSingleIframe=getSingle(function(){
     var iframe=document.createElement('iframe');
     document.body.appendChild(iframe);
     return iframe;
 });
 
 document.getElementById('btn').onclick=function(){
     var createSingleIframe=new createSingleIframe();
     createSingleIframe.src='https:www.baidu.com';
 }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值