初始化实例变量
将带有值类型(非引用的)的初始化值(例如类型为数字, 布尔值, null, undefined 或字符串的值)的变量声明/初始化代码直接放在 prototype 原型中。 这可以避免每次调用构造函数时不必要地运行初始化代码。 (这个方法无法应用到初始化值由构造器参数决定或构造时状态不确定的实例变量上。)
例如, 比起写:
以下为引用的内容:
foo.Bar = function() {
this.prop1_ = 4;
this.prop2_ = true;
this.prop3_ = [];
this.prop4_ = 'blah';
};不如写:
foo.Bar = function() {
this.prop3_ = [];
};
foo.Bar.prototype.prop1_ = 4;
foo.Bar.prototype.prop2_ = true;
foo.Bar.prototype.prop4_ = 'blah';
谨慎地使用闭包(closure)
闭包是 JavaScript 中一个强大而有用的特性; 但是, 它们也有不好的地方, 包括:
它们是最常见的内存泄漏源头。
创建一个闭包比创建一个没有闭包的内联函数明显要慢, 比起重用一个静态函数则更慢。 例如:
以下为引用的内容:
function setupAlertTimeout() {
var msg = '要显示的消息';
window.setTimeout(function() { alert(msg); }, 100);
}比下面的代码慢:
function setupAlertTimeout() {
window.setTimeout(function() {
var msg = '要显示的消息';
alert(msg);
}, 100);
}更比下面的代码慢:
function alertMsg() {
var msg = '要显示的消息';
alert(msg);
}
function setupAlertTimeout() {
window.setTimeout(alertMsg, 100);
}
他们增加了作用域链(scope chain)的层级。 当浏览器解析属性时, 作用域链的每一个层级都必须被检查一次。 在下面的例子中:
以下为引用的内容:
var a = 'a';
function createFunctionWithClosure() {
var b = 'b';
return function () {
var c = 'c';
a;
b;
c;
};
}
var f = createFunctionWithClosure();
f();
当 f 被调用时, 引用 a 比引用 b 慢, 它们都比引用 c 要慢。
查看 IE+JScript Performance Recommendations Part 3: JavaScript Code inefficiencies 获得更多有关在 IE 中使用闭包的信息。
避免使用 with
在你的代码中避免使用 with. 它对性能有非常坏的影响, 因为它修改了作用域链, 让查找在其它作用域的变量变得代价高昂。
避免浏览器内存泄漏
内存泄漏对 Web 应用而言是个很普遍的问题, 它会带来严重的性能问题。 当浏览器的内存使用上升时, 你的 Web 应用, 连同用户系统的其他部分, 都会变慢。 Web 应用最常见的内存泄漏原因是: 在 JavaScript 脚本引擎和浏览器 DOM 的 C++ 对象实现间的循环引用(例如, 在 JavaScript 脚本引擎和 Internet Explorer 的 COM 基础架构间, 或者 JavaScript 引擎和 Firefox 的 XPCOM 基础架构间)。
下面是避免内存泄漏的一些经验法则:
使用一个事件系统来附加事件处理函数
最常见的循环引用模式 [ DOM 元素 --》 事件处理函数 --》 闭包作用域 --》 DOM ] 在 这篇 MSDN 的 Blog 文章中讨论过了。 为避免这个问题, 可以使用一个经过严格测试的事件系统来附件事件处理函数, 例如 Google doctype, Dojo, or JQuery.
另外, 在 IE 中使用内联(inline)的事件处理函数会导致另外一类泄漏。 这不是通常的循环引用泄漏, 而是内存中临时匿名脚本对象的泄漏。 详情请查看 理解和解决 IE 泄漏模式(Understanding and Solving Internet Explorer Leak Patterns) 的 “DOM 插入顺序泄漏模型(DOM Insertion Order Leak Model)” 一节, 另外在 JavaScript Kit 教程 中还有一个例子。
避免使用扩展(expando)属性
扩展属性是附加到 DOM 元素上的任意 JavaScript 属性, 也是循环引用的常见原因。 你能够在使用扩展属性时不导致内存泄漏, 但是很容易不小心就引入一个泄漏。 这个泄漏的模式是 [ DOM 元素 --》 扩展属性 --》 中间对象 --》 DOM 元素 ]。 最好的方法就是避免使用它们。 如果你要使用它们, 就只使用简单的值类型。 如果你要非简单的类型, 那么在不再需要扩展属性时将它设为空(null)。 参见 理解和解决 IE 泄漏模式(Understanding and Solving Internet Explorer Leak Patterns) 中的 “循环引用(Circular References)” 一节.
第1页:JavaScript 代码优化(1) 第2页:JavaScript 代码优化(2)
© CopyRight 2008-2010, JSJGZ.CN, 计算机故障 Inc. All Rights Reserved
闽ICP备09000710号 增值电信业务经营许可证闽B2-20080004号 Rss订阅