jQuery 性能优化手册 推荐

在twitter上发现了<jQuery Performance Rules>这篇文章, 简单的摘译了一下:

总是从ID选择器开始继承
在class前使用tag
将jquery对象缓存起来
掌握强大的链式操作
使用子查询
对直接的DOM操作进行限制
冒泡
消除无效查询
推迟到 $(window).load
压缩js
全面掌握jquery库
1. 总是从ID选择器开始继承
在jquery中最快的选择器是ID选择器. 因为它直接来自于Javascript的getElementById()方法.

复制代码 代码如下:


<div id=“content”>
<form method=“post” action=“/”>
<h2>Traffic Light</h2>
<ul id=“traffic_light”>
<li><input type=“radio” class=“on” name=“light” value=“red” /> Red</li>
<li><input type=“radio” class=“off” name=“light” value=“yellow” /> Yellow</li>
<li><input type=“radio” class=“off” name=“light” value=“green” /> Green</li>
</ul>
<input class=“button” id=“traffic_button” type=“submit” value=“Go” />
</form>
</div>


像这样选择按钮是低效的:

复制代码 代码如下:


var traffic_button = $(‘#content .button');


用ID直接选择按钮效率更高:

复制代码 代码如下:


var traffic_button = $(‘#traffic_button');


选择多个元素

提到多元素选择其实是在说DOM遍历和循环, 这些都是比较慢的东西.为了提高性能, 最好从就近的ID开始继承.

复制代码 代码如下:


var traffic_lights = $(‘#traffic_light input');


2. 在class前使用tag

第二快的选择器是tag选择器($('head')). 同理,因为它来自原生的getElementsByTagName() 方法.

复制代码 代码如下:


<div id=“content”>
<form method=“post” action=“/”>
<h2>Traffic Light</h2>
<ul id=“traffic_light”>
<li><input type=“radio” class=“on” name=“light” value=“red” /> Red</li>
<li><input type=“radio” class=“off” name=“light” value=“yellow” /> Yellow</li>
<li><input type=“radio” class=“off” name=“light” value=“green” /> Green</li>
</ul>
<input class=“button” id=“traffic_button” type=“submit” value=“Go” />
</form>
</div>


总是用一个tag name来限制(修饰)class (并且不要忘记就近的ID):

复制代码 代码如下:


var active_light = $(‘#traffic_light input.on');


注意: 在jquery中Class是最慢的选择器. IE浏览器下它会遍历所有DOM节点不管它用在那里.

不要用用tag name来修饰ID. 下面的例子将会遍历所有的div元素来查找id为'content'的哪一个节点:

复制代码 代码如下:


var content = $(‘div#content');


用ID修饰ID也是画蛇添足:

复制代码 代码如下:


var traffic_light = $(‘#content #traffic_light');


3.将jquery对象缓存起来

要养成将jquery对象缓存进变量的习惯.

永远不要这样做:

复制代码 代码如下:


$(‘#traffic_light input.on).bind('click‘, function(){…});
$('#traffic_light input.on).css(‘border', ‘3px dashed yellow');
$(‘#traffic_light input.on).css('background-color‘, ‘orange‘);
$('#traffic_light input.on).fadeIn('slow');


最好先将对象缓存进一个变量然后再操作:

复制代码 代码如下:


var $active_light = $(‘#traffic_light input.on');
$active_light.bind(‘click', function(){…});
$active_light.css(‘border', ‘3px dashed yellow');
$active_light.css(‘background-color', ‘orange');
$active_light.fadeIn('slow');


为了记住我们本地变量是jquery的封装, 通常用一个$作为变量前缀. 记住,永远不要让相同的选择器在你的代码里出现多次.

缓存jquery结果,备用

如果你打算将jquery结果对象用在程序的其它部分,或者你的function会多次执行, 那么就将他们缓存到一个全局变量中.

定义一个全局容器来存放jquery结果, 我们就可以在其它函数引用它们:

复制代码 代码如下:


// 在全局范围定义一个对象 (例如: window对象)
window.$my =
{
// 初始化所有可能会不止一次要使用的查询
head : $(‘head'),
traffic_light : $(‘#traffic_light'),
traffic_button : $(‘#traffic_button')
};

function do_something()
{
// 现在你可以引用存储的结果并操作它们
var script = document.createElement('script');
$my.head.append(script);

// 当你在函数内部操作是, 可以继续将查询存入全局对象中去.
$my.cool_results = $(‘#some_ul li');
$my.other_results = $(‘#some_table td');

// 将全局函数作为一个普通的jquery对象去使用.
$my.other_results.css(‘border-color', ‘red');
$my.traffic_light.css(‘border-color', ‘green');
}


4. 掌握强大的链式操作

上面的例子也可以写成这样:

复制代码 代码如下:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wdssdy.html