龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > web编程 > Javascript编程 >

网易邮箱前端JavaScript编码规范(1)(2)

时间:2013-03-06 14:58来源:未知 作者:admin 点击:
分享到:
网易邮箱页面在window只允许定义三种变量1:全局变量;2:常量;3:类。任何业务逻辑都需要通过类方法或者示例方法实现。前两种变量在之前文章中已经

网易邮箱页面在window只允许定义三种变量——1:全局变量;2:常量;3:类。任何业务逻辑都需要通过类方法或者示例方法实现。前两种变量在之前文章中已经介绍,在此不再累述,接下来详细介绍类定义和使用的规范。

定义类是通过一个闭包完成的:

  1. (function(){   
  2.   //第一步:引入存在的类。引入support类   
  3.   var Support = window.Support;    
  4.     
  5.   //$是网易邮箱基础库“base”的引用稍后会介绍   
  6.   //第二步:定义类。可以认为返回了一个类定义 function(){},并在window下定义一个Image类   
  7.   var Image = $.createClass("Image");    
  8.     
  9.   //可以认为是jQuery的extend方法    
  10.     
  11.   //第三步:定义类属性/方法定义   
  12.   $.Object.extend(Image,{   
  13.    _language : null,   //内部属性   
  14.    getSize  : fImageGetSize   
  15.   });   
  16.   //第四步:定义实例属性/方法定义   
  17.   $.Object.extend(Image.prototype,{   
  18.    name  : null,   
  19.    url   : null,   
  20.    ext   : null,   
  21.    width  : 0,   
  22.    height  : 0,   
  23.    setName  : fImageSetName,   
  24.    getName  : fImageGetName,   
  25.    init  : fImageInit   
  26.   });   
  27.   //第五步:方法实现    
  28.     
  29.   function fImageGetSize(nWidth,nHeight){   
  30.    return nWidth*nHeight;   
  31.   }    
  32.     
  33.   function fImageSetName(sName){   
  34.    var oImage = this;   
  35.    oImage.name = sName;   
  36.   }    
  37.     
  38.   function fImageGetName(){   
  39.    var oImage = this;   
  40.    return oImage.name;   
  41.   }    
  42.     
  43.   function fImageInit(sUrl){   
  44.    var oImage = this;   
  45.    oImage.url = sUrl;   
  46.    oImage.ext = Support.getExt(sUrl);   
  47.    oImage.width = Support.getWidth(sUrl);   
  48.    oImage.height = Support.getHeight(sUrl);   
  49.   }    
  50.     
  51.  })(); 

我们可以看到,这个闭包完成了以下几件事情:

1.引入这个类需要用到的其他类。

2.定义这个类。

3.定义类的属性和方法。

4.定义类的实例属性和方法。

5.类和实例方法的实现。

在命名上,我们遵循了一下规则:

1.类名首个字母必需大写,例如Image,Support等。

2.属性名需要是有意义的名词,首字母小写,例如oImage.width。

3.方法名需要是有意义的动词[+名词],首字母小写,例如Support.getWidth

4.如果不希望被其他方法调用,需要在属性或者方法名前面加“_”,例如oImage._language

5.如果不希望被子类调用,需要在属性或者方法名前加“_”,例如oImage.__fire()

这里需要特别说明以下几点:

1.方法的定义不是通过匿名函数来定义,而是集中在类定义的下面来实现。这样的好处是能在最开始将类的属性方法定义都罗列出来,便于通过源码查看到对应属性和方法。

2.在类/实例方法中,使用局部变量代替this。this不是一个好的玩意儿,一不小心就会被this搞晕。使用局部变量能够尽量避免这样的问题,也能够在压缩混淆的时候效果更好。

3.在实际开发过程中,每个类定义都单独一个js实现。

除了类的定义,闭包不实现 任何其他逻辑。使用闭包能够将很多变量约束在闭包作用域中,并且能够在压缩混淆中效果更好,除此之外,使用闭包定义类,在之后将介绍到的动态加载成为了一件十分容易的事情,稍后会和大家一起分享。

【责任编辑:张伟 TEL:(010)68476606】
精彩图集

赞助商链接