Javascript编程规范
原文地址:https://code.google.com/p/j-et/wiki/JavascriptCodingStandard
?
规范理念
Any violation to this guide is allowed if it enhances readability.
所有的代码都要变成可供他人容易阅读的。
--引用自Dojo Javascript 语法规范
规范详解命名规范必须使用 Tab 键进行代码缩进,以节约代码大小(建议设置编辑器的tab为4个空格的宽度)接口风格
- 必须使用 Tab 键进行代码缩进,以节约代码大小(建议设置编辑器的tab为4个空格的宽度)接口风格
?
结构规则例如类驼峰式ModuleClass()公有方法混合式getPosition()公有变量混合式frameStyle常量大写式DEFAULT_FRAME_LAYOUT?
- 其他建议风格,非必要
?
结构规则私有方法混合,例子:mixedCase私有变量混合,例子:mixedCase方法(method)参数混合,例子:mixedCase, mixedCase本地(local)变量混合,例子:mixedCase, mixedCase?
- 所有语句结束后,必须使用 ; 号结束所有变量必须是有意义的英文,严厉禁止拼音变量允许使用公认英文缩写类命名必须是驼峰式常量必须所有单词大写,并且每个单词间加下划线枚举类型时,枚举的命名必须有意义,枚举与枚举成员必须以驼峰式常量和枚举必须在最前端定义,merge 时注意,必须把常量与枚举定义的文件放在文件列表的第一位变量内的简写单词不能全大写XmlDocument strHtml"on"只能用作事件的命名函数开头必须是有意义的动词或动词短语私有类的变量属性成员 建议 使用混合式命名,并前面下下划线临时的全局变量放到一个全局的哈希表里,方便变量回收所有全局变量必须初始化,尽量少用全局变量大括号前面不能有换行符保留字以及特有的dom属性不能作为变量名
特殊命名约定前面加 “is” 的变量名应该为布尔值,亦可使用 “can” “has” “should”前面加 ”str” 的变量名应该为字符串前面加 “arr” 的变量名应该为数组前面加 “num” 或 “count” 的变量名应该为数字“o” 作为局部变量或参数,表示为Object“e” 作为局部变量或参数,表示为Element“evt” 作为局部变量或参数,表示为event“err” 作为局部变量或参数,表示为error重复变量建议使用 "i", "j", "k" (依次类推)等名称的变量(全世界公认)能缩写的单词尽量缩写避免产生令人误解的布尔值 isNotNumber isNan处理错误的变量,必须在后面跟着 “Error”初始化用的函数 必须使用 “init” 开头,如果一个页面只有初始化可以单独使用 init()尽量做有意义的代码折行,不要让一行代码过长。(HTML 字符串除外)操作符 建议 使用空格隔开函数调用和方法 避免 使用空白逗号(,) 建议 使用空白隔开。不允许频繁使用 previousSibling 和 nextSibling
词法结构普通代码段应该看起来如下:while(!isDone){? ? ? doSomething();? ? ? isDone = moreToDo();}if 语句应该看起来像这样:if(someCondition){? ? ? ? statements;}elseif(someOtherCondition){? ? statements;}else{? ? statements;}for 语句应该看起来像这样:for(initialization; condition; update){? ? ? ? statements;}while 语句应该看起来像这样:while(!isDone){? ? ? ? doSomething();? ? isDone = moreToDo();}do ... while 语句应该看起来像这样:do{? ? ? ? statements;}while(condition);switch 语句应该看起来像这样:switch(condition){case ABC:? ? statements;? ? // ?fallthroughcase DEF:? ? statements;? ? break;default:? ? ? ? statements;? ? break;}try ... catch 语句应该看起来像这样:try{? ? statements;}catch(ex){? ? statements;}finally{? ? statements;}单行的 if - else,while 或者 for 语句也必须加入括号:if(condition){ statement;}while(condition){ statement;}for(intialization; condition; update){ statement;}
注释规范一些你不打算给其他人使用的函数,建议添加 @ignore 让文档输出时可以忽略这段注释一些相关的功能相关的函数,建议加上@see Function 来对上下文做索引对于一些函数不建议或则需要注意的使用方法,必须加上 @deprecated作为提醒每个js文件的文件头都必须包含 @fileoverview @author, 建议加上@version每个函数都必须使用JsDoc 来注释他的用意每个带参数的函数必须包含 @param每个有返回值的函数必须包含 @return构造函数必须加上 @constructor继承函数建议加上 @base 表示其继承于哪个类常用全局变量建议使用 JsDoc 的注释方式一般的变量及局部变量才用 // 方式进行注释,建议在需要做注释的语句的上一行其他详情请参考 JsDoc 注释方法
其他String 优化循环体内的字符串累加使用join方式。 例如:? ? ? ? var r = [];? ? ? ? for (var i=0;i<100;i++){? ? ? ? ? ? ? ? r.push("hello");? ? ? ? }? ? ? ? var k = r.join("");
Switch 建议采用hash-tableswitch 可以才用 Object代替 例如:? ? ? ? var a = {? ? ? ? ? ? ? ? "1":doAction1,? ? ? ? ? ? ? ? "2":doAction2,? ? ? ? }? ? ? ? ? ? ? ? function doAction1(){?? ? ? ? }?? ? ? ? function doAction2(){?? ? ? ? }?? ? ? ? a[1]();
不建议使用eval不推荐使用eval来执行脚本。除非用来解释json数据。
注意 IE 的内存泄露问题
- 普通代码段应该看起来如下:
while(!isDone){? ? ? doSomething();? ? ? isDone = moreToDo();}if 语句应该看起来像这样:if(someCondition){? ? ? ? statements;}elseif(someOtherCondition){? ? statements;}else{? ? statements;}for 语句应该看起来像这样:for(initialization; condition; update){? ? ? ? statements;}while 语句应该看起来像这样:while(!isDone){? ? ? ? doSomething();? ? isDone = moreToDo();}do ... while 语句应该看起来像这样:do{? ? ? ? statements;}while(condition);switch 语句应该看起来像这样:switch(condition){case ABC:? ? statements;? ? // ?fallthroughcase DEF:? ? statements;? ? break;default:? ? ? ? statements;? ? break;}try ... catch 语句应该看起来像这样:try{? ? statements;}catch(ex){? ? statements;}finally{? ? statements;}单行的 if - else,while 或者 for 语句也必须加入括号:if(condition){ statement;}while(condition){ statement;}for(intialization; condition; update){ statement;}注释规范一些你不打算给其他人使用的函数,建议添加 @ignore 让文档输出时可以忽略这段注释一些相关的功能相关的函数,建议加上@see Function 来对上下文做索引对于一些函数不建议或则需要注意的使用方法,必须加上 @deprecated作为提醒每个js文件的文件头都必须包含 @fileoverview @author, 建议加上@version每个函数都必须使用JsDoc 来注释他的用意每个带参数的函数必须包含 @param每个有返回值的函数必须包含 @return构造函数必须加上 @constructor继承函数建议加上 @base 表示其继承于哪个类常用全局变量建议使用 JsDoc 的注释方式一般的变量及局部变量才用 // 方式进行注释,建议在需要做注释的语句的上一行其他详情请参考 JsDoc 注释方法
其他String 优化循环体内的字符串累加使用join方式。 例如:? ? ? ? var r = [];? ? ? ? for (var i=0;i<100;i++){? ? ? ? ? ? ? ? r.push("hello");? ? ? ? }? ? ? ? var k = r.join("");
Switch 建议采用hash-tableswitch 可以才用 Object代替 例如:? ? ? ? var a = {? ? ? ? ? ? ? ? "1":doAction1,? ? ? ? ? ? ? ? "2":doAction2,? ? ? ? }? ? ? ? ? ? ? ? function doAction1(){?? ? ? ? }?? ? ? ? function doAction2(){?? ? ? ? }?? ? ? ? a[1]();
不建议使用eval不推荐使用eval来执行脚本。除非用来解释json数据。
注意 IE 的内存泄露问题
- String 优化
循环体内的字符串累加使用join方式。 例如:? ? ? ? var r = [];? ? ? ? for (var i=0;i<100;i++){? ? ? ? ? ? ? ? r.push("hello");? ? ? ? }? ? ? ? var k = r.join("");Switch 建议采用hash-tableswitch 可以才用 Object代替 例如:? ? ? ? var a = {? ? ? ? ? ? ? ? "1":doAction1,? ? ? ? ? ? ? ? "2":doAction2,? ? ? ? }? ? ? ? ? ? ? ? function doAction1(){?? ? ? ? }?? ? ? ? function doAction2(){?? ? ? ? }?? ? ? ? a[1]();不建议使用eval不推荐使用eval来执行脚本。除非用来解释json数据。注意 IE 的内存泄露问题