《改善javascript程序的188个建议》摘抄

来源:互联网 发布:java三元运算符 编辑:程序博客网 时间:2024/06/05 05:48

1:不要使用汉字命名。


2:最大限度的避免使用全局变量;使用以下方法减少全局变量污染:

var My = {};My.name = {    "first-name" : " first ",    "last-name" : " last "};My.work = {    number : 123,    one : {        name : " one ",        time : "2012-9-14 12:55",        city : "beijing"    },    two : {        name : "two",        time : "2012-9-12 12:42",        city : "shanghai"    }};

使用My.work['one']['name']调用某一个变量。


3:并且尽量在函数体的顶部声明所有将要用到的变量。


4:浮点运算是不精确的,整数运算是精确的;eg: 0.1+0.2=0.3000000000000000000000004; (1+2)/10=0.3


5:检测数据类型方法,

方法一:typeof

返回number,string,boolean,object,function,undefined其中的一种,null返回object而不是null;不能够检测复杂的数据类型;

function type(o){    return (o===null)?"null":(typeof o);}

方法二:constructor属性

value.constructor,构造函数的属性值;

null和defined

var t=null;alert(typeof t);//objectalert(t&&t.constructor);//nullvar m=undefined;alert(typeof m);//undefined

数值直接量要加括号:

alert((10).constructor)

方法三:toString()

以字符串形式返回[object class];

var d=new Date();var m=Object.prototype.toString;alert(m.apply(d));

5:正确使用parseInt

parseInt('123abc');//123parseInt('1.23');//1parseInt('.123');//NaN

对parseInt加上基数参数:

parseInt('10', [radix]);//将‘10’按照radix(进制)转换为10进制整数;

6:句尾加分号;长句换行不要形成语义,避免自动加分号产生错误;


7:正确使用NaN和isFinite

NaN参与运算结果为NaN;

NaN !== NaN;

isNaN(NaN)==  true;

isFinite会筛除掉NaN和无穷大;

isFinite会试图将运算数转换为数字;

使用自定义函数来判断是否为数字:

var isNumber=function isNumber(value){return typeof value === 'number'&&isFinite(value);}

8:使用===和!==,不要使用== 和 !=

===会先判断类型是否相同,然后判断值,都相同时为true


9:不要使用++和--


10:不要信任hasOwnProperty,因为其有可能被清空;


11:避免使用eval();


12:避免使用continue;


13:switch中case记得加上break防止贯穿;


14:不要省略块标志;


15:推荐使用第二种,理解函数就是数值的概念;

                //No1function abcd(){alert(1);}abcd();//No2var f=function abc(){alert(1);}f();


16:不要使用类型构造器,也不要使用new


17:少用函数迭代;


--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------Chapter 1 ends-------------------------------------------------------------------------------------------

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------


18:连接字符串开销很大,尽量避免多次连接大的字符串;


19:load 会在所有内容包括图片加载完成后触发,DOMContentLoaded 在文档结构加载完毕的时候触发,比load早触发;


20:beforeunload在离开当前页面之前触发;





0 0
原创粉丝点击