js单例模式

今天进一步了解了js单例模式,下面说一下我的理解。

在实际问题中,我们在js文件中声明过多的函数和全局变量,或者导入多个js文件,都可能导致全局变量的命名冲突问题。

单例模式要求类只能实例化一次并且提供实例的全局接口。通过单例模式,我们可以为某些方法和属性规划一个命名空间来解决问题。

比较简单的单例模式:

var test = {
    a: 1,
    b: 2,
    demo: function() {
        alert(a)
    }
}
较为常见的时下面的情况:

function a(){
    }
function b(){
    }
function c(){
    }  //函数过多就有可能造成冲突
可以通过以下方式解决:

var test = {
    testa:1,
    testb:2,
    meta:function (){
}
    metb:function (){
}
    metc:function() {
}
}
这样就可以通过对象test来访问对象内部的属性和方法。

当导入多个js文件时,也可以通过创建多个不同的对象来将各自的变量和方法进行“隔离”,避免冲突。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值