JavaScript 中的单例以及模块模式
来源:互联网 发布:软件开发等级考试 编辑:程序博客网 时间:2024/06/05 16:55
一、单例
单例指的是只有一个实例的对象,JavaScript以对象字面量的方式创建单例对象。
var singleton = { name: value, method: function(){ //方法 }};
任何在函数中定义的变量,都可以认为是私有变量。私有变量包括函数的参数,局部变量和在函数内部定义的其他函数。
如果在函数内部创建一个闭包,那么闭包通过自己的作用域链也可以访问函数的私有变量。利用这一点,就可以创建访问私有变量的公有方法,也叫特权方法。
function Person(name){ this.getName = function(){ return name; }; this.setName = function (value) { name = value; };} var person = new Person("latency");alert(person.getName()); //"latency"person.setName("cheng");alert(person.getName()); //"cheng"以上代码的构造函数中定义了两个特权方法:getName()和setName()。这两个方法都可以在构造函数外部使用,而且都有权访问私有变量name。但在Person构造函数外部,没有任何办法访问name。由于这两个方法是在构造函数内部定义的,它们作为闭包能够通过作用域链访问name。私有变量name在Person的毎一个实例中都不相同,因为每次调用构造数都会重新创建这两个方法。
三、模块模式
上面介绍的是为自定义类型创建私有变量和特权方法。模块模式则是为单例创建私有变量和特权方法。
var singleton = function(){ //私有变量和函数 var privateVariable = 10; function privateFunction(){ return false; } //特权方法和属性 return { publicProperty : true, publicMethod: function(){ privateVariable++; return privateFunction(); } }}();这个模块模式使用了一个返回对象的匿名函数。在这个匿名函数内部,将一个对象字面量作为函数的值返回。其中包含可以公开的属性和方法。因为这个匿名函数是在函数内部定义的,所以可以访问私有的变量和函数。这个对象字面量定义的是单例的公共接口。
当必须要创建一个对象并以某些数据对其进行初始化,同时还要公开一些能够访问这些私有数据的方法时,就可以用模块模式。
阅读全文
0 0
- JavaScript 中的单例以及模块模式
- Javascript中的单例和模块模式
- JavaScript中的单例模式
- javascript中的单例模式
- JavaScript中的单例模式
- JavaScript设计模式-单例模式、模块模式
- 关于javascript的闭包、模块化以及单例模式
- javaScript中的设计模式(5)单例模式
- Javascript单例模式
- JavaScript 单例模式
- javascript 单例模式
- JavaScript单例模式
- javascript 单例模式
- javascript 单例模式
- javascript--单例模式
- JavaScript 单例模式
- javascript单例模式
- Javascript单例模式
- Pycharm2017专业版安装以及激活
- Redis学习五(Spring Data Redis)
- 你知道python教程哪个好吗?
- dubbo+zookeeper探索小结
- STL空间配置器
- JavaScript 中的单例以及模块模式
- Quartz 教程
- 遇到多个构造器参数时要考虑用构造器。
- 深度学习:神经网络中的前向传播和反向传播算法推导
- fatal: Unable to create '........./.git/index.lock': File exists.
- iOS调试——打全局断点后总是在断在App delegate里处理办法
- 【HDU-1232】 畅通工程
- iOS开发自定义简洁实用的高可扩展的Model基类
- ionic2+cordova 遇到的坑