【仅供内部供应商使用,不提供对外解答和培训】
【仅供内部供应商使用,不提供对外解答和培训】
语句必须都有分号结尾,除了for, function, if, switch, try, while。
如果仅依靠语句间的隐式分隔, 有时会很麻烦,你自己更能清楚哪里是语句的起止。而且有些情况下, 漏掉分号会很危险:
MyClass.prototype.myMethod = function() {
return 42;
} //这里没有分号
(function() {
// 做一些初始化的事情
})();上面这段语句会报 JavaScript 错误 。上的语句会解释成, 一个函数带一匿名函数作为参数而被调用, 返回42后, 又一次被"调用", 这就导致了错误。
错误:
var arr = [1,2,3,];//数组最后一个逗号不必要存在
FR.Ajax({
url:'http://someurl',
data:{'paraA':'aa','paraB':'bb'},//作为一个json对象,这里的逗号是多余的,且在IE下可能抛错
});正确:
var arr = [1, 2, 3];
var ajaxConfig = {
url:'http://someurl',
data:{'paraA':'aa','paraB':'bb'}
};不推荐:
if (condition)statement;
正确:
if (condition) {
statement;
}eval() 会让程序执行的比较混乱, 当 eval() 里面包含用户输入的话就更加危险. 可以用其他更佳的, 更清晰, 更安全的方式写你的代码, 所以一般情况下请不要使用 eval(). 当碰到一些需要解析序列化串的情况下(如, 计算 RPC 响应), 使用 eval 很容易实现。
使用 with 让你的代码在语义上变得不清晰. 因为 with 的对象, 可能会与局部变量产生冲突, 从而改变你程序原本的用义。
不推荐:
var obj = new Object(); var arr = new Array();
正确:
var obj = {};
var arr = [];对 Array 用 for-in 循环有时会出错. 因为它并不是从 0 到 length - 1 进行遍历, 而是所有出现在对象及其原型链的键值. 下面就是一些失败的使用案例:
function printArray(arr) {
for (var key in arr) {
print(arr[key]);
}
}
printArray([0,1,2,3]); // 这个正常工作
var a = new Array(10);
printArray(a); // 这个就会出错了错误:
var arr = ['aa', 'bb', 'cc', 'dd'];
for (var el in arr) {
// do something with el;
}正确:
var arr = ['aa', 'bb', 'cc', 'dd'];
for (var i = 0, len = arr.length; i < len; i ++) {
var el = arr[i];
// do somthing with el;
}错误:
FS = {};
FR = {};
contentPane = {};正确:
window.FS = {};
window.FR= {};
window.contentPane = {};错误:
for(var i = 0; i < 3; i++){
var i = 0;//导致死循环
}FR.ajax()函数会对data自动进行编码,避免了参数编码错误
错误:
$.ajax({
url : "http://www.baidu.com",
data: {"keywords": "中文"},
success : function() {
// do something
}
});正确:
FR.ajax({
url : "http://www.baidu.com",
data: {"keywords": "中文"},
success : function() {
// do something
}
});以下划线标记私有方法增加代码的可读性。
错误:
FR.Button = FR.extend(FR.Widget, /**@lends FR_Button*/{
defaultConfig: function () {
return {cls : 'fr-btn'};
}
};正确:
FR.Button = FR.extend(FR.Widget, /**@lends FR_Button*/{
_defaultConfig: function () {
return {cls : 'fr-btn'};
}
};前者的函数存在浏览器兼容问题,低版本的IE是不支持的。
错误:
var date = new Date("2014-01-01");正确:
var date = new Date(2014, 1,1);