前端设计模式之单例模式

本文深入解析单例模式的实现方式,通过闭包私有化变量,确保对象唯一性。同时介绍如何将任意函数转换为单例模式,适用于前端开发中资源优化及避免多次实例化的问题。

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

单例模式:构造函数每次创建对象,只有一个被创建.

单纯写个单例模式并不难,利用闭包,可以私有化变量.

 1 var single = (function(){
 2     var demo;
 3     return function(name){
 4         if(demo){
 5             return demo;
 6         }
 7         this.name = name;
 8         demo = this;
 9     }
10 })

 

 

但是想要把任何函数都变成单例模式的函数,需要利用一下工具函数:

function getSigleFn(fn){
    var result ;
    return function(){
        if(result){
            return result
        }
       result = fn.apply(this, arguments)//只有第一次执行;会走这里.这个arguements是指单例以后返回的函数的参数
       return result;
    }
}

这两个函数的写法总结:

1,都是利用了闭包保存要返回的值,并判断返回值有没有值,有就返回,没有就说明是第一次执行

2,始终要弄清楚你要的结果是啥,第一个要的是事例对象,第二个要的是一个新函数.

转载于:https://www.cnblogs.com/dangdanghepingping/p/10122864.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值