js单例模式详解实例
什么是单例?
单例要求一个类有且只有一个实例,提供一个全局的访问点。因此它要绕过常规的控制器,使其只能有一个实例,供使用者使用,而使用着不关心有几个实例,因此这是设计者的责任
In JavaScript, Singletons serve as a shared resource namespace which isolate implementation code from the global namespace so as to provide a single point of access for functions.
在javascript中,单例被当做一个全局的命名空间,提供一个访问该对象的一个点。
使用场景
In practice, the Singleton pattern is useful when exactly one object is needed to coordinate others across a system.
类比
单例有点类似于一个小组的小组长,在一段时间内只有一个小组长,有小组长来指定组员的工作,分配和协调和组员的工作。
实例1:这个是最简单的单例,通过key,value的形式存储属性和方法
var A = { xx:3, yy:4, B:function(el){ }, C:function(el){ }, D:function(el){ }, E:function(el){ } }
实例2:首先创建一个实例的引用,然后判断这个实例是否存在,如果不存在那么就创建,存在的话,就直接返回,保证有且只有一个。
var mySingleton = (function () { // Instance 存储一个单例实例的引用 var instance; function init() { // Singleton // 私有的方法和变量 function privateMethod(){ console.log( "I am private" ); } var privateVariable = "Im also private"; return { // 共有的方法和变量 publicMethod: function () { console.log( "The public can see me!" ); }, publicProperty: "I am also public" }; }; return { // 如果实例不存在,那么创建一个 getInstance: function () { if ( !instance ) { instance = init(); } return instance; } }; })(); var singleA = mySingleton; var singleB = mySingleton; console.log( singleA === singleB ); // true
实例3:
var SingletonTester = (function () { // options: an object containing configuration options for the singleton // e.g var options = { name: "test", pointX: 5}; function Singleton( options ) { // set options to the options supplied // or an empty object if none are provided options = options || {}; // set some properties for our singleton this.name = "SingletonTester"; this.pointX = options.pointX || 6; this.pointY = options.pointY || ; } // our instance holder var instance; // an emulation of static variables and methods var _static = { name: "SingletonTester", // Method for getting an instance. It returns // a singleton instance of a singleton object getInstance: function( options ) { if( instance === undefined ) { instance = new Singleton( options ); } return instance; } }; return _static; })(); var singletonTest = SingletonTester.getInstance({ pointX: 5 }); // Log the output of pointX just to verify it is correct // Outputs: 5 console.log( singletonTest.pointX );
单例模式
- var single = (function(){
- var unique;
- function getInstance(){
- if( unique === undefined ){
- unique = new Construct();
- }
- return unique;
- }
- function Construct(){
- // ... 生成单例的构造函数的代码
- }
- return {
- getInstance : getInstance
- }
- })();
实现1: 最简单的对象字面量
- var singleton = {
- attr : 1,
- method : function(){ return this.attr; }
- }
- var t1 = singleton ;
- var t2 = singleton ;
实现2:构造函数内部判断
- function Construct(){
- // 确保只有单例
- if( Construct.unique !== undefined ){
- return Construct.unique;
- }
- // 其他代码
- this.name = "NYF";
- this.age="24";
- Construct.unique = this;
- }
- var t1 = new Construct() ;
- var t2 = new Construct() ;
实现3 : 闭包方式
- var single = (function(){
- var unique;
- function Construct(){
- // ... 生成单例的构造函数的代码
- }
- unique = new Constuct();
- return unique;
- })();
总结
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。