JavaScript设计模式之单体模式全面解析
单体是一个用来划分命名空间并将一些相关的属性与方法组织在一起的对象,如果她可以被实例化的话,那她只能被实例化一次(她只能嫁一次,不能二婚)。
单体模式是javascript里面最基本但也是最有用的模式之一。
特点
1. 可以用来划分命名空间,从而清除全局变量所带来的危险或影响。
2. 利用分支技术来来封装浏览器之间的差异。
3. 可以把代码组织的更为一体,便于阅读和维护。
单体模式的基本写法
/ 最基本的单体模式 / var her = { name: 'Anna', sex: 'women', say: function(){ // 一些处理逻辑...... }, doing: function(){ // 另一些处理函数...... } }
1. 划分命名空间
var box = { width: 0, height: 0, getArea: function(){ return this.width this.width; // js中对象成的访问必须是显示的,即this是不能省略的 }, init: function(w, h){ // width = w; // height = h;这种方式相当于定义了两个全局变量,(没加var声明的变量为全局变量) // 并不是对对象width和height的赋值 // 狼蚁网站SEO优化是正确的 this.width = w; this.height = h; } } //box划分了一个命名空间,命名空间里的变量只在空间里有效
上面的单体中的所有的成员以及方法都是公有的(public),也就是在单体的外部可以对她们进行任意的改动(但不能访问其中的局部变量),那为什么说单体提供了一个命名空间呢?
别急,我们接着往下看
var box = { width:0, height:0,//单体的变量 getArea:function(){ return width height;// width,height其实并不是单体的变量,而是在init中定义的全局变量 } init:function(w,h){ width = w; height = h; } }// init中width,height其实并不是单体的变量 window.onload = function(){ var init = box.getArea(); alert(init); }
由于没有对init中的width,height进行初始化,所以会报错,这样改一下
var box = { width:0, height:0, getArea:function(){ return width height; }, init:function(w,h){ width = w; height = h; } } window.onload = function(){ width = 0; height = 0; //or box.init(0,0); var init = box.getArea(); alert(init); }
发现可以了,由于init和 getArea所用的width和height并不是归单体所有的变量,而是一个全局变量,所以我们可以在单体外面进行随意调用而不受影响、
var box = { width: 0, height: 0, getArea: function(){ return width height;//js中对象成的访问必须是显示的,即this是不能省略的 }, init:function(w,h){ width = w; height = h; } }//这里的width,height其实并不是单体的对象 window.onload = function(){ width = 0; height = 0; var width = box.getArea(); alert(width); }
这样写又会报错了,可见我们以上的方式对于全局变量并没有建立起一个命名空间,全局变量为我们带来了危险。所以最上面的写法是对的,我们来验证一下
var box = { width: 2, height: 2, getArea: function(){ return this.width this.height;/ /js中对象成的访问必须是显示的,即this是不能省略的 }, init:function(w,h){ this.width = w; this.height = h; } } window.onload = function(){ width = 0; // 不会影响单体中的局部变量也就是命名空间 height = 0; // 不会影响单体中的局部变量也就是命名空间 var width = box.getArea(); alert(width); }
可见在window.onload中的width 和height已经没有干扰了,因为单体为单体中的width和height建立了一个命名空间。
2. 成员的属性
虽然在javascript中没有这么严格的面向对象(oop),我们可以借助闭包来进行一个模仿,毕竟有的变量设为public是很不好的。
var her = (function(){ var name = 'Anna'; var sex = 'women'; return { getArea: function(){ return name + 'is a' + sex; }, init:function(b){ name = b; } } })(); window.onload = function(){ her.name = 'Jock'; // 无法访问 alert(ger.getArea()); her.init('Lous'); alert(her.getArea()); }
私有变量、方法是只读的,公有变量、方法是可读可写的。
访问
对于私有成员,直接访问即可,前面不用加任何修饰,
对于公有的访问在单体作用域内前面要加上“this.”,在单体作用域外前面要加上“her.”(单体名字.)
3.利用分支技术来来封装浏览器之间的差异
注意的地方
a. 一定要用闭包,实现即时绑定
b. 每个分支之间用分号隔开
c. 返回的是分支的名字
d. 调用的时候用单体名+分支的方法名;
// 利用单体的分支技术来定义XHR(XMLHttpRequest)对象,必须要用闭包才可以实现 var XHR = (function(){ //The three branches var standard = { cXHR:function(){ return new XMLHttpRequest(); } }; var activeXNew = { cXHR:function(){ return new ActiveXObject('Msxml2.XMLHttp'); } }; var activeXOld = { cXHR:function(){ return new ActiveXObject('Microsoft.XMLHttp'); } }; //To assign(分配) the branch, try each method;return whatever doesn't fail var testObject; try{ testObject = standard.cXHR(); return standard;// return this branch if no error was thrown }catch(e){ try{ testObject = activeXNew.cXHR(); return activeXNew; }catch(e){ try{ testObject = activeXOld.cXHR(); return activeXOld; }catch(e){ throw new Error('Create the XMLHttpRequestObject failed!'); } } } })(); window.onload = function(){ alert(XHR.cXHR()); }
以上所述是长沙网络推广给大家介绍的JavaScript设计模式之单体模式全面解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程