JavaScript 设计模式学习 Singleton
作者:bea
代码如下: /* Basic Singleton. */ var Singleton = { attribute1: true, attribute2: 10, method1: function() { }, method2: function(arg) { } }; 单件模式最主要的用途之一就是命名空间: /* GiantCorp namespace. */ var GiantCorp = {}; GiantCorp.Common = {
代码如下:
/* Basic Singleton. */
var Singleton = {
attribute1: true,
attribute2: 10,
method1: function() {
},
method2: function(arg) {
}
};
单件模式最主要的用途之一就是命名空间:
/* GiantCorp namespace. */
var GiantCorp = {};
GiantCorp.Common = {
// A singleton with common methods used by all objects and modules.
};
GiantCorp.ErrorCodes = {
// An object literal used to store data.
};
GiantCorp.PageHandler = {
// A singleton with page specific methods and attributes.
};
利用闭包在单件模式中实现私有方法和私有变量:
GiantCorp.DataParser = (function() {
// Private attributes.
var whitespaceRegex = /s+/;
// Private methods.
function stripWhitespace(str) {
return str.replace(whitespaceRegex, '');
}
function stringSplit(str, delimiter) {
return str.split(delimiter);
}
// Everything returned in the object literal is public, but can access the
// members in the closure created above.
return {
// Public method.
stringToArray: function(str, delimiter, stripWS) {
if(stripWS) {
str = stripWhitespace(str);
}
var outputArray = stringSplit(str, delimiter);
return outputArray;
}
};
})(); // Invoke the function and assign the returned object literal to
// GiantCorp.DataParser.
实现Lazy Instantiation 单件模式:
MyNamespace.Singleton = (function() {
var uniqueInstance; // Private attribute that holds the single instance.
function constructor() { // All of the normal singleton code goes here.
...
}
return {
getInstance: function() {
if(!uniqueInstance) { // Instantiate only if the instance doesn't exist.
uniqueInstance = constructor();
}
return uniqueInstance;
}
}
})();
MyNamespace.Singleton.getInstance().publicMethod1();
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 网页全屏显示代码说明分析
- javascript 处理HTML元素必须避免使用的一种方法
- javascript 写的一个简单的timer
- jquery imgareaselect 使用利用js与程序结合实现图片剪切
- Javascript this指针
- javascript 进度条 实现代码
- JS input 数字验证代码
- 关于取不到由location.href提交而来的上级页面地址的解决办法
- window.parent调用父框架时 ie跟火狐不兼容问题
- javascript EXCEL 操作类代码
- JavaScript this 深入理解
- Google Map API更新实现用户自定义标注坐标
- JavaScript Konami Code 实现代码
- JavaScript 获取事件对象的注意点
- javascript CSS画图之基础篇
- JQuery 表格操作(交替显示、拖动表格行、选择行等)
- JavaScript 设计模式学习 Factory
- 实现lightBox时的样式与行为分离减少JS
- JQuery UI皮肤定制