JS设计模式---单例模式、发布订阅模式

本文深入探讨JavaScript中的两种重要设计模式——单例模式和发布订阅模式。单例模式确保一个类只有一个实例,并提供全局访问点。发布订阅模式则通过事件中心实现对象间的解耦通信,允许发送者和接收者无需直接交互。
摘要由CSDN通过智能技术生成
JS设计模式--单例模式
     定义 :  无论实例化多少次对象,永远返回第一次的实例对象
一:不使用单例模式
// 定义一个构造函数,然后创建一个实例对象
class Dialog{
    constructor(){
        this.odiv = document.createElement('div')
        console.log('创建一个div元素');
    }
}
let d1 = new Dialog()
console.log(d1);
let d2 = new Dialog()
console.log(d2);
console.log(d1 == d2);
//输出结果如下

 

二:使用单例模式:
//需求:创建多个实例对象的时候,要想每次只执行一次costructor,每次new出来的都是同一个实例,这样就创建了一个div
//创建自调用函数,避免全局污染
let singleFun = (function(){
        //instance避免全局污染,相对于外层函数为局部变量,使用闭包将instance局部变量返回,相对于内层函数为全局变量,内层函数也可以使用instance
        let instance = null;   //null为false
        class Dialog{
            constructor(){
                this.odiv = document.createElement('div')
                console.log('创建一个div元素');
            }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值