最近在读《编写可维护的javascript》这本书,为了加深记忆,简单做个笔记,同时也让没有读过的同学有一个大概的了解。
一、编程风格
程序是写给人读的,所以一个团队的编程风格要保持一致。
1、缩进:一种是利用制表符缩进,一种是使用空格符缩进,各有利弊,任选一种,保持一致即可。个人比较喜欢制表符缩进。
2、语句结尾需要加上分号,避免没必要的BUG。
3、命名:首先要语义化,使用驼峰式命名法,小驼峰即首字母小写,之后每个单词首字母大写;大驼峰即首字母大写,之后同小驼峰;变量名前缀应该是名词(myName),函数名前缀应该是动词(getName),常量全部使用大写字母(MY_NAME),非常直观,构造函数使用大驼峰命名法(DateFormat)。
4、注释:单行注释用//,多行注释用/**/,单行注释//之后总有一个空格,下一行代码缩进层级应与注释保持一致。难以理解或是容易被认为是错误的代码前应该加上注释。
5、花括号对齐方式推荐这种:
if( ){ }else{ }
不推荐这种:
if( ) { } else { }
6、避免使用with语句。
7、for in 语句是用来遍历对象的属性值的,遍历数组请使用for循环
8、在函数顶部定义变量,变量前一定要写上var语句,定义多个变量可以用逗号隔开,如:
var name = "wangmeijian", age = 23, sex = "boy";
同时,字符串统一使用双引号。
9、判断两个值是否相等时,使用===或!==,不推荐使用==和!=,因为javascript具有强制类型转换机制会造成意想不到的结果。
10、javascript中,eval()不是唯一可以执行javascript字符串的函数,使用Function构造函数也可以做到,setTimeout()和setInterval()也可以。例如:
var wmj=new Function( "alert('Hi')" ) wmj() setTimeout( "document.body.style.background='red'",100 ); setInterval( "document.write('It is now"+ (new Date()) +"')",1000 ) //书上这个例子有错误,本文已更正
这三种用法都比较少见。
11、原始包装类型:先看一段代码
var name = "wangmeijian"; console.log( name.toUpperCase() );
一个字符串是没有方法的,但你仍然可以使用toUpperCase()之类方法,这是因为在这条语句背后javascript引擎创建了String类型的新实例,紧跟着就被销毁了。String就是该字符串的原始包装类型。