JavascriptCodingStandard
Javascript 代码规范
规范理念
Any violation to this guide is allowed if it enhances readability.
所有的代码都要变成可供他人容易阅读的。
--引用自Dojo Javascript 语法规范
规范详解
命名规范
- 必须使用 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;
// fallthrough
case 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-table
switch 可以才用 Object代替 例如:
var a = {
"1":doAction1,
"2":doAction2,
}
function doAction1(){
}
function doAction2(){
}
a[1]();
- 不建议使用eval
不推荐使用eval来执行脚本。除非用来解释json数据。
- 注意 IE 的内存泄露问题
分享到:
相关推荐
Arch-Linux-Install-ScriptArch_Linux_安装脚本_Arch-Linux-Installer
"cacti-plugin-arch-2.0.tar.gz" 是一个针对Cacti的插件包,用于扩展Cacti的功能,提供更丰富的监控选项。此插件名为“Arch”,可能是对系统架构或性能分析相关的增强。 该压缩包文件的名称表明它是版本2.0,通常这...
基于android8.1源码平台中生成的jar,亲测可用!!!!
变系数ARCH-M模型是时间序列分析领域的重要研究对象,其核心在于通过截面似然估计来检验模型是否具有条件异方差性(ARCH效应)。首先,我们来探讨一下条件异方差性的概念,它是指在时间序列分析中,随机变量的条件...
标题中的"Python库 | arch-4.11-cp35-cp35m-win32.whl"指的是一个特定版本的Python库,名为“arch”,版本为4.11,适用于Python 3.5解释器(由"cp35"标识),且是针对32位Windows操作系统("win32")的。"cp35m"表示...
python库。 资源全名:arch-4.8.0-cp27-cp27m-win32.whl
安装克隆这个仓库git clone https://github.com/jannispinter/arch-openwrt-buildroot.git构建 docker 镜像 cd arch-openwrt-buildrootdocker build -t= " arch-openwrt-buildroot:trunk " . 最后的点表示Dockerfile...
Next Generation On Demand (NGOD) Asset Architecture Comcast-SP-NGOD-ASSET-ARCH-I03-100731 Issued July 31, 2010
资源来自pypi官网。 资源全名:arch-4.17-cp39-cp39-manylinux1_x86_64.whl
Next Generation On Demand (NGOD) Overall Architecture Comcast-SP-NGOD-GEN-ARCH-I03-100731 Issued July 31, 2010
解压缩后的"arch-snds100"文件包含了一系列源代码文件和配置文件,这些文件通常分为几个部分: 1. **头文件(Header Files)**:定义了驱动程序使用的函数原型、结构体和常量,供其他模块引用和调用。 2. **C...
我的Arch_Linux安装步骤和日志_Arch-Linux-install-log
资源来自pypi官网。 资源全名:arch-4.9.1-cp36-cp36m-macosx_10_6_intel.whl
arch-model-estimation_solution.ipynb
Arch_Linux_盒装安装媒介的小盒子_arch-media-box-typst
**arch-box** 是一个专为Arch Linux自动化构建的项目,旨在为不同的虚拟化和容器环境提供预配置的Arch Linux镜像。它支持多种提供程序,包括 **Vagrant** 和 **VirtualBox**,同时也可能适用于 **QEMU** 等其他虚拟...
arch_linux_安装日志,为了方便查看。_arch-linux-notes
### ARCH-GARCH模型详解 #### 一、时间序列波动性的概念与特征 时间序列波动性主要指的是资产回报的条件方差(conditional variance),这在金融领域尤为重要。在传统的AR(1)模型中,如: \[ y_{t+1} = \beta_1 y_...