javascript的书写规范

  • javascript书写命名规范:
    常量名:
    全部大写并单词间用下划线分隔
    如:CSS_BTN_CLOSE、TXT_LOADING
    对象的属性或方法名:
    小驼峰式(little camel-case)
    如:init、bindEvent、updatePosition
    示例:Dialog.prototype = {
 init: function () {},
          bindEvent: function () {},
          updatePosition: function () {}
          …
          };

类名(构造器):
-->小驼峰式但首字母大写
-->如:Current、DefaultConfig
函数名:
-->小驼峰式
-->如:current()、defaultConfig()
变量名:
-->小驼峰式
-->如:current、defaultConfig
私有变量名:
-->小驼峰式但需要用_开头
-->如:_current、_defaultConfig

  • 代码格式:
"="前后需要跟空格
","后面需要跟空格
JSON对象需格式化对象参数
if、while、for、do语句的执行体用"{}"括起来
  • "{}"格式如下:
if (a==1) {
  //代码
};
  • 避免额外的逗号:
var arr = [1,2,3,];

for-in循环体中必须用hasOwnProperty方法检查成员是否为自身成员,避免来自原型链上的污染。

  • 长语句可考虑断行:
TEMPL_SONGLIST.replace('{TABLE}', da['results'])
  .replace('{PREV_NUM}', prev)
  .replace('{NEXT_NUM}', next)
  .replace('{CURRENT_NUM}', current)
  .replace('{TOTAL_NUM}', da.page_total);

为了避免和JSLint的检验机制冲突,“.”或“+”这类操作符放在行尾。

/*global alert: true, console: true, top: true, setTimeout: true */
  • 使用严格的条件判断符。用===代替==,用!==代替!=,避免掉入==造成的陷阱在条件判断时,这样的一些值表示false
null
undefined与null相等
字符串''
数字0
NaN

在==时,则会有一些让人难以理解的陷阱。

undefined与null相等
一个是number一个是string时,会尝试将string转换为number
尝试将boolean转换为number
0或1
尝试将Object转换成number或string

而这些取决于另外一个对比量,即值的类型,所以对于0、空字符串的判断,建议使用===。
===会先判断两边的值类型,类型不匹配时为false

  • 下面类型的对象不建议用new构造:
new Number
new String
new Boolean
new Object //用{}代替
new Array //用[]代替

引用对象成员用obj.prop代替obj["prop"],除非属性名是变量。

  • 从number到string的转换:
/** 推荐写法*/
var a = 1;
typeof(a); //"number"
console.log(a); //1
var aa=a+'';
typeof(aa); //"string"
console.log(aa); //'1'
/** 不推荐写法*/
new String(a)或a.toString()

从string到number的转换,使用parseInt,必须显式指定第二个参数的进制。

/** 推荐写法*/
var a = '1';
var aa = parseInt(a,10);
typeof(a); //"string"
console.log(a); //'1'
typeof(aa); //"number"
console.log(aa); //1

从float到integer的转换。

/** 推荐写法*/
Math.floor/Math.round/Math.ceil
/** 不推荐写法*/
parseInt

字符串拼接应使用数组保存字符串片段,使用时调用join方法。避免使用+或+=的方式拼接较长的字符串,每个字符串都会使用一个小的内存片段,过多的内存片段会影响性能。

/**推荐的拼接方式array的push、join*/
var str=[],
  list=['测试A','测试B'];
for (var i=0 , len=list.length; i < len; i++) {
  str.push( '<div>'+ list[i] + '</div>');
};
console.log(str.join('')); //<div>测试A</div><div>测试B</div>
/** 不推荐的拼接方式+=*/
var str = '',
  list=['测试A','测试B'];
for (var i = 0, len = list.length; i< len; i++) {
  str+='<div>' + list[i] + '</div>';
};
console.log(str); //<div>测试A</div><div>测试B</div>
  • 尽量避免使用存在兼容性及消耗资源的方法或属性
不要使用with,void,evil,eval_r,innerText
  • 注重HTML分离, 减小reflow, 注重性能。

以上JavaScript的书写规范希望帮助,不足之处还望大家共同探讨。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 命名规范:常量名 全部大写并单词间用下划线分隔 如:CSS_BTN_CLOSE、TXT_LOADING 对象的属性...
    努力为爱阅读 768评论 1 5
  • 基本准则 符合web标准,html语义化;html,css,JavaScript分离;代码简洁有序,尽可能减少冗余...
    喵呜君阅读 817评论 0 1
  • Web前端开发规范文档 规范目的: 使开发流程更加规范化。 通用规范: TAB键用两个空格代替(WINDOWS下T...
    荞叶阅读 550评论 0 1
  • 为什么翻开了《解密》? 说来是前几年的因由。那时的我,对国内连续剧制作的粗制滥造深恶痛绝,基本不看。也是先生的推荐...
    原来是二姐阅读 202评论 0 0
  • 一叶而知秋,一念而情深…… 一·相遇 深秋,飘叶的林荫小道,相遇措不及妨。 我独自一人,漫无目地的走在那条熟悉的林...
    古城月色阅读 267评论 0 0