JavaScript之编码规范 推荐


Posted in Javascript onMay 23, 2012

一、命名
1、应给变量和函数取一个含义确切的名称,不要随意命名。
2、非构造函数采用驼峰命名法,尽量采用动宾结构,以与变量名相区别,如getName或IsFull。构造函数(即自定义类型)名称首字母大写,以与非构造函数相区别,如Person。
3、变量采用驼峰命名法。由于JavaScript是一种弱类型语言,因此建议在变量名称前加前缀:整形(i),浮点数(f),布尔型(b),字符串(s),数组(a)。但不强制这么做,可根据个人爱好选择,选择好后就不要混用加前缀和不加前缀这两种方式了。

二、布局
1、空格。
a)var与变量名之间留一个空格,变量名与等号之间留一个空格,等号与初始值之间留一个空格,初始值与分号之间不留空格。如:var i = 10;
b)使用字面量方式声明引用类型变量时,各个属性与冒号之间不留空格,冒号与初始值之间留一个空格。如:

var Person = { 
age: 16, 
name: "Sam" 
};

c)function与函数名之间留一个空格,函数名与()之间不留空格,()与{之间留一个空格。
d)函数的各个参数之间留一个空格。
e)if、while、for与左括号之间留一个空格,以强调关键字;switch、with与左括号之间不留空格。
f) 二元操作符与左右两个操作数之间留一个空格。当某行代码较长时,也可不留空格。
2、换行。
a)每行语句占用一行,不要多个语句一行。
b)if、while、for等块级作用域后的大括号{不要另起一行,就放在关键字同一行。
3、缩进。
a)缩进使用4个空格,不要使用tab。
b)作用域不一样时就应当进行缩进,以显示出其层次关系。

三、注释
1、合理添加注释。注释不能完全没有,也不是越多越好。给重要的方法、变量和算法(或其他需要注意的问题)添加注释即可。
2、修改源代码时,需要同步修改注释,保持两者的一致。
3、不要在代码中使用html方式的注释。

四、规范
1、申明变量时必须加var关键字。虽然JavaScript允许不加var关键字,此时成为全局变量,但这是导致问题的一个来源。
2、申明变量时必须同时进行初始化,之后最好不要再改变变量的数据类型了。
3、语句末尾可以加分号的,必须加分号。
4、if、while、for等仅有一条语句时,也需要放在大括号内。
5、不要随意使用全局变量,如果不得不使用,最好只用一个全局变量。
6、JavaScript与html、css之间应保持松散耦合。html是数据层,css是表现层,JavaScript是行为层,三者应避免紧密的耦合,否则会导致后期难以维护。html中不要有具体的JavaScript代码,全部采用包含外部文件的方式;JavaScript中也尽量不要使用innerHTML等插入大量html元素,应考虑将元素放在html中,只不过初始隐藏即可;JavaScript中不要直接修改css中的具体属性,而应通过className来间接修改。
7、不要修改不是由你所有的对象,不给其实例或原型添加属性或方法,也不要重复定义其已有的方法。否则,当该对象的新版本添加了同名的属性或方法时,会导致潜在的难以察觉的问题。解决方案有两种:一是继承,二是包含。
8、使用命名空间来防止多个库之间的冲突,可参考YUI库的组织方式。
9、对于代码中出现的字面量,应将其放在某个变量的属性中,属性名首字母或所有字母大写(模拟其他语言中的define或enum)。如:

var Color = { 
RED: 1, 
BLUE: 2, 
GREEN: 3 
};

10、对函数中传入的参数进行检查。若为基本类型,使用typeof;若为引用类型,使用instanceOf;若要检查某个对象是否包含某个方法,则对该方法使用typeof操作符,并与字符串"undefined"比较。

五、性能
1、避免全局查找。使用全局变量和函数的开销要比使用局部变量和函数大,因为全局变量和函数涉及到作用域链的查找。因此,当函数中多次使用全局变量时,就会进行多次作用域链的查找,为了避免这个问题,可以将多次使用的全局变量赋值给一个局部变量,以后都使用该局部变量。
2、避免使用witch语句。with语句会创建自己的作用域,从而导致额外的开销。
3、避免属性查找。属性查找是一个O(n)操作,对象上的任何属性查找都比访问变量和数组花费更多时间(访问变量和数组是O(1)操作)。因此,如果多次用到同一个属性,则应将其保存在局部变量中。如:

var sUrl = window.location.href; 
var sData = sUrl.substring(sUrl.indexOf("?"));
Javascript 相关文章推荐
奇妙的js
Sep 24 Javascript
jQuery打印图片pdf、txt示例代码
Jul 22 Javascript
JavaScript实现同时调用多个函数的方法
Nov 09 Javascript
AngularJS基础 ng-srcset 指令简单示例
Aug 03 Javascript
Bootstrap导航条可点击和鼠标悬停显示下拉菜单
Nov 25 Javascript
如何学JavaScript?前辈的经验之谈
Dec 28 Javascript
js HTML5 canvas绘制图片的方法
Sep 08 Javascript
Three.js利用dat.GUI如何简化试验流程详解
Sep 26 Javascript
Vue2.0 给Tab标签页和页面切换过渡添加样式的方法
Mar 13 Javascript
vue展示dicom文件医疗系统的实现代码
Aug 27 Javascript
vue进入页面时滚动条始终在底部代码实例
Mar 26 Javascript
JS实现移动端点击按钮复制文本内容
Jul 28 Javascript
javascript的数据类型、字面量、变量介绍
May 23 #Javascript
网页源代码保护(禁止右键、复制、另存为、查看源文件)
May 23 #Javascript
通过js动态操作table(新增,删除相关列信息)
May 23 #Javascript
JavaScript基础语法让人疑惑的地方小结
May 23 #Javascript
利用javascript解决图片缩放及其优化的代码
May 23 #Javascript
JavaScript 图像动画的小demo
May 23 #Javascript
JavaScript学习笔记记录我的旅程
May 23 #Javascript
You might like
php合并数组array_merge函数运算符加号与的区别
2008/10/31 PHP
PHP的基本常识小结
2013/07/05 PHP
遍历指定目录,并存储目录内所有文件属性信息的php代码
2016/10/28 PHP
浅谈PHP无限极分类原理
2019/03/14 PHP
Tips 带三角可关闭的文字提示
2010/10/06 Javascript
JS 控制小数位数的实现代码
2011/08/02 Javascript
jQuery异步验证用户名是否存在示例代码
2014/05/21 Javascript
基于OL2实现百度地图ABCD marker的效果
2015/10/01 Javascript
解决js图片加载时出现404的问题
2020/11/30 Javascript
PHP捕捉异常中断的方法
2016/10/24 Javascript
微信小程序 WXDropDownMenu组件详解及实例代码
2016/10/24 Javascript
js封装成插件_Canvas统计图插件编写实例
2017/09/12 Javascript
nodejs异步编程基础之回调函数用法分析
2018/12/26 NodeJs
node.js基于socket.io快速实现一个实时通讯应用
2019/04/23 Javascript
移动端吸顶fixbar的解决方案详解
2019/07/17 Javascript
vue全局使用axios的操作
2020/09/08 Javascript
js实现简易点击切换显示或隐藏
2020/11/29 Javascript
Vue通过阿里云oss的url连接直接下载文件并修改文件名的方法
2020/12/25 Vue.js
[04:52]2015国际邀请赛LGD战队晋级之路
2015/08/14 DOTA
Python Mysql自动备份脚本
2008/07/14 Python
python抓取京东价格分析京东商品价格走势
2014/01/09 Python
Python实现子类调用父类的方法
2014/11/10 Python
详解python使用pip安装第三方库(工具包)速度慢、超时、失败的解决方案
2018/12/02 Python
python实现Oracle查询分组的方法示例
2020/04/30 Python
Python3爬虫关于识别点触点选验证码的实例讲解
2020/07/30 Python
澳大利亚最好的在线时尚精品店:Princess Polly
2018/01/03 全球购物
英国最大的宝石首饰超市:QP Jewellers
2018/09/23 全球购物
澳大利亚顶级美发和美容贸易超市:glamaCo
2020/01/19 全球购物
银行实习生自我鉴定范文
2013/09/19 职场文书
工程学毕业生自荐信
2014/06/14 职场文书
护士先进个人总结
2015/02/13 职场文书
2015年反腐倡廉工作总结
2015/05/14 职场文书
施工现场安全管理制度
2015/08/05 职场文书
写作技巧:优秀文案必备的3种结构
2019/08/19 职场文书
redis限流的实际应用
2021/04/24 Redis
MySQL数据库优化之通过索引解决SQL性能问题
2022/04/10 MySQL