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 相关文章推荐
用函数式编程技术编写优美的 JavaScript
Nov 25 Javascript
js DOM模型操作
Dec 28 Javascript
Jquery插件之多图片异步上传
Oct 20 Javascript
js Calender控件使用详解
Jan 05 Javascript
xmlplus组件设计系列之按钮(2)
Apr 26 Javascript
jQuery Json数据格式排版高亮插件json-viewer.js使用方法详解
Jun 12 jQuery
基于AngularJS的拖拽文件上传的实例代码
Jul 15 Javascript
详解vue.js数据传递以及数据分发slot
Jan 20 Javascript
vue最简单的前后端交互示例详解
Oct 11 Javascript
vue基于两个计算属性实现选中和全选功能示例
Feb 08 Javascript
微信小程序前端自定义分享的实现方法
Jun 13 Javascript
vue 全局封装loading加载教程(全局监听)
Nov 05 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
打造计数器DIY三步曲(中)
2006/10/09 PHP
详解:――如何将图片储存在数据库里
2006/12/05 PHP
检查php文件中是否含有bom的函数
2012/05/31 PHP
查找mysql字段中固定字符串并替换的几个方法
2012/09/23 PHP
php引用传值实例详解学习
2013/11/06 PHP
php 微信开发获取用户信息如何实现
2016/12/13 PHP
LBS blog sql注射漏洞[All version]-官方已有补丁
2007/08/26 Javascript
jquery判断元素是否隐藏的多种方法
2014/05/06 Javascript
jQuery实现行文字链接提示效果的方法
2015/03/10 Javascript
浅谈document.write()输出样式
2015/05/07 Javascript
分享javascript计算时间差的示例代码
2020/03/19 Javascript
HTML5基于Tomcat 7.0实现WebSocket连接并实现简单的实时聊天
2016/10/31 Javascript
最常见的左侧分类菜单栏jQuery实现代码
2016/11/28 Javascript
Vue2.0实现购物车功能
2017/06/05 Javascript
EasyUI的DataGrid每行数据添加操作按钮的实现代码
2017/08/22 Javascript
解决循环中setTimeout执行顺序的问题
2018/06/20 Javascript
layui多iframe页面控制定时器运行的方法
2019/09/05 Javascript
使用webpack和rollup打包组件库的方法
2021/02/25 Javascript
各个系统下的Python解释器相关安装方法
2015/10/12 Python
Python编程pygal绘图实例之XY线
2017/12/09 Python
numpy.random.seed()的使用实例解析
2018/02/03 Python
opencv python 基于KNN的手写体识别的实例
2018/08/03 Python
Python生命游戏实现原理及过程解析(附源代码)
2019/08/01 Python
Django使用 Bootstrap 样式修改书籍列表过程解析
2019/08/09 Python
python3.7 openpyxl 删除指定一列或者一行的代码
2019/10/08 Python
python返回数组的索引实例
2019/11/28 Python
Django中FilePathField字段的用法
2020/05/21 Python
Notino芬兰:购买香水和化妆品
2019/04/15 全球购物
什么情况下你必须要把一个类定义为abstract的
2013/01/06 面试题
写演讲稿要注意的六件事
2014/01/14 职场文书
《欢乐的泼水节》教学反思
2014/04/22 职场文书
通信工程求职信
2014/07/16 职场文书
学习张林森心得体会
2014/09/10 职场文书
不服从公司安排检讨书
2014/09/24 职场文书
2015年网络舆情工作总结
2015/07/24 职场文书
Python turtle实现贪吃蛇游戏
2021/06/18 Python