十个迅速提升JQuery性能让你的JQuery跑得更快


Posted in Javascript onDecember 10, 2012

本文提供即刻提升你的脚本性能的十个步骤。不用担心,这并不是什么高深的技巧。人人皆可运用!这些技巧包括:
使用最新版本
合并、最小化脚本
用for替代each
用ID替代class选择器
给选择器指定前后文
建立缓存
避免DOM操作
避免使用concat(),利用join()处理长字串
返回false值
利用小抄和参考文档
使用最新版本
jQuery一直处于不断的开发和改进过程中。 John 和他的团队不断研究着提升程序性能的新方法。
一点题外话,几个月前他还发布了Sizzle,一个据说能在Firefox中把程序性能提升3倍的JS选择器库。
如果你不想时刻关注是否有新版本,然后再花时间下载上传,Google 就又能帮你一把了。他们的服务器上存储了大量Ajax库供您选择。

<!-- 利用一个简单的script标签调用API --> 
<script type="text/javascript" src="http://www.google.com/jsapi"></script> 
<script type="text/javascript"> 
/* 加载 jQuery v1.3.2 */ 
google.load ("jquery", "1.3.2", {uncompressed: false}); 
/* 加载完成后弹出消息 */ 
function onLoad () { 
alert ("jQuery + Google API!"); 
} 
google.setOnLoadCallback (onLoad); 
</script>

另一个更为简单快速的方法是直接使用脚本链接。如果要使用特定版本的jQuery,你可以使用上面的方法;如果想直接使用最新版,下面这句代码就够了:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.js"></script>

特定版本的还可以这样加载:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>

合并、最小化脚本
大部分浏览器都不能同时处理多个脚本文件,所以它们都是排队加载——加载时间也相应地延长了。
考虑到你网站的每个页面都会加载这些脚本,你应该考虑把它们放到单个文件中,然后利用压缩工具(比如 Dean Edwards 的这款)把它们最小化。更小的文件无疑将带来更快的加载速度。
JavaScript和CSS压缩的目的是在保持脚本的执行性能的同时,减少数据传递的字节数(可以通过减小原始文件,也可以利用gzip。大多数产品级的网络服务器都把gzip作为HTTP协议的一部分)。引自 YUI compressor,一款 jQuery官方推荐的压缩脚本的工具。
用for替代each
原生函数总是比辅助组件更快。
如果遇到需要遍历对象的情况(如从远程接收的JSON对象),你最好重写你的(JSON)对象为一个数组,数组的循环处理要容易些。
利用Firebug,我们能测定每个函数的执行时间。
var array = new Array (); 
for (var i=0; i<10000; i++) { 
array[i] = 0; 
} 
console.time('native'); //原生for函数 
var l = array.length; 
for (var i=0; i<10000; i++) { 
}

十个迅速提升JQuery性能让你的JQuery跑得更快 
上面的结果显示原生代码只需2毫秒就做到的事,利用jQuery的each方法需要26毫秒。而且这还只是我在本机上测试一个基本上啥也没做的函数的结果,当遇到更复杂的情况,例如设置css属性或DOM操作时,时间差异肯定更大。
用ID替代class选择器
利用ID选择对象要好得多,因为这时jQuery会使用浏览器的原生函数getElementByID()来获取对象,查询速度很快。
因此,比起利用那些方便的css选择技巧,使用更为复杂的选择器也是值得的(jQuery也为我们提供了复杂选择器)。你也可以手工书写自己的选择器(其实比你想象中简单),或者为你想要选择的元素指定一个有ID的容器。
//下例创建一个列表并且填充条目内容 
//然后每个条目都被选择一次 
//首先使用class选择 
console.time('class'); 
var list = $('#list'); 
var items = ' 
'; 
for (i=0; i<1000; i++) { 
items += ' 
item 
'; 
} 
items += ' 
'; 
list.html (items); 
for (i=0; i<1000; i++) { 
var s = $('.item' + i); 
} 
console.timeEnd('class'); 
//然后利用ID选择 
console.time('id'); 
var list = $('#list'); 
var items = ' 
'; 
for (i=0; i<1000; i++) { 
items += ' 
item 
'; 
} 
items += ' 
'; 
list.html (items); 
for (i=0; i<1000; i++) { 
var s = $('#item' + i); 
} 
console.timeEnd('id');

上面的例子很好地说明了不同选择方式之间的显著性能差异。请看下图,利用class来做选择,时间无限增大,甚至超过了五秒。
给选择器指定前后文
jQuery的参考文档里说:传递给jQuery() 原始DOM节点的前后文(如果没有东西被传递,则前后文为整个文档)。目的是连同选择器一起,实现更为准确的查询。
所以,如果你一定要利用class来指定目标,至少为选择器指定上下文,以免jQuery费精力去遍历整个DOM文档:
与其这样写:
$('.class').css ('color' '#123456');

为选择器加上前后文比较好(expression: 目标选择器;context: 前后文):
$(expression, context)

也就是说:
$('.class', '#class-container').css ('color', '#123456');

这样做要快得多,因为它不用遍历整个DOM。只要找到#class-container就好了。
建立缓存
不要犯不断重新选择同一个东西的错误。你应该把你要处理的元素缓存为一个变量。
更不要在一个循环里重复选择同一个元素!这样做十分影响速度!
$('#item').css('color', '#123456'); 
$('#item').html('hello'); 
$('#item').css('background-color', '#ffffff'); 
// 这样写更好 
$('#item').css('color', '#123456').html('hello').css('background-color', '#ffffff'); 
// 甚至这样 
var item = $('#item'); 
item.css('color', '#123456'); 
item.html('hello'); 
item.css('background-color', '#ffffff'); 
// 遇到循环,这样做非常不好 
console.time('no cache'); 
for (var i=0; i<1000; i++) { 
$('#list').append(i); 
} 
console.timeEnd('no cache'); 
// 下面这样要好得多 
console.time('cache'); 
var item = $('#list'); 
for (var i=0; i<1000; i++) { 
item.append (i); 
} 
console.timeEnd('cache');

避免DOM操作
DOM操作应该越少越好,因为诸如prepend(),append(),after()的插入动作都很费时。上面的例子如果用html()会更快:
var list = ''; 
for (var i=0; i<1000; i++) { 
list += ' 
'+i+' 
'; 
} 
('#list').html (list);

避免使用concat(),利用join()处理长字串
听起来可能挺奇怪,不过这样做真的能提升速度,尤其是当连接特别长的字串时。先建立一个数组,放入你想要串联的东西。join()方法比字符串的concat()函数要快得多。
var array = []; 
for (var i=0; i< =10000; i++) { 
array[i] = ' 
'+i+''; 
} 
$('#list').html(array.join (''));

“ += 操作符更快——比把字串片段放到数组中然后join起来还要快”,“作为字串缓冲(string buffer)的数组在大部分浏览器中都比string.prototype.concat.apply方法效率更高,Windows下的Firefox 2.0.0.14例外。” — Tom Trenka
返回false值
您可能已经注意到,如果函数执行后不返回false,你就会被跳转到页面顶部。如果页面较长,这种反应是很烦人的。
所以,与其这样:
$('#item').click (function () { 
// stuff here 
});

不如多加一句:
$('#item').click (function () { 
// stuff here 
return false; 
});

额外小贴士 ? 小抄和参考文档
十个迅速提升JQuery性能让你的JQuery跑得更快 
这条建议并不直接提升函数的执行速度,不过如果你肯花时间在这上面,研究研究这些小抄和参考文档,你将来定能节约很多时间。
请在手边随时放一张小抄以作快速参考。
Javascript 相关文章推荐
通过JAVASCRIPT读取ASP设定的COOKIE
Feb 15 Javascript
jquery json 实例代码
Dec 02 Javascript
禁止IE用右键的JS代码
Dec 30 Javascript
用简洁的jQuery方法toggleClass实现隔行换色
Oct 22 Javascript
AngularJS 异步解决实现方法
Jun 12 Javascript
JavaScript数组push方法使用注意事项
Oct 30 Javascript
JS 实现百度搜索功能
Feb 01 Javascript
jQuery实现文件编码成base64并通过AJAX上传的方法
Apr 12 jQuery
Vue中的情侣属性$dispatch和$broadcast详解
Mar 07 Javascript
javascript中数组的常用算法深入分析
Mar 12 Javascript
vue配置接口域名方法总结
May 12 Javascript
canvas 中如何实现物体的框选
Aug 05 Javascript
JQuery each()函数如何优化循环DOM结构的性能
Dec 10 #Javascript
jquery的$getjson调用并获取远程的JSON字符串问题
Dec 10 #Javascript
如何用ajax来创建一个XMLHttpRequest对象
Dec 10 #Javascript
iframe 上下滚动条如何默认在下方实现原理
Dec 10 #Javascript
Ajax执行顺序流程及回调问题分析
Dec 10 #Javascript
js切换div css注意的细节
Dec 10 #Javascript
不同的jQuery API来处理不同的浏览器事件
Dec 09 #Javascript
You might like
php采用session实现防止页面重复刷新
2015/12/24 PHP
php session实现多级目录存放实现代码
2016/02/03 PHP
php实现无限级分类查询(递归、非递归)
2016/03/10 PHP
Tips 带三角可关闭的文字提示
2010/10/06 Javascript
jQuery EasyUI API 中文文档 - EasyLoader 加载器
2011/09/29 Javascript
js自动闭合html标签(自动补全html标记)
2012/10/04 Javascript
Lazy Load 延迟加载图片的jQuery插件中文使用文档
2012/10/18 Javascript
JS 如何获取radio选中后的值及不选择取radio的值
2013/10/28 Javascript
分享一款基于jQuery的视频播放插件
2014/10/09 Javascript
JavaScript判断是否是微信浏览器
2016/06/13 Javascript
NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法
2016/07/26 NodeJs
基于vue.js实现图片轮播效果
2016/12/01 Javascript
js放大镜放大购物图片效果
2017/01/18 Javascript
浅谈mint-ui 填坑之路
2017/11/06 Javascript
深入理解ES6之数据解构的用法
2018/01/13 Javascript
JS删除数组里的某个元素方法
2018/02/03 Javascript
js实现移动端轮播图
2020/12/21 Javascript
Vue插槽原理与用法详解
2019/03/05 Javascript
layui实现三级联动效果
2019/07/26 Javascript
vue2.0项目集成Cesium的实现方法
2019/07/30 Javascript
js实现微信聊天界面
2020/08/09 Javascript
[55:32]2018DOTA2亚洲邀请赛 4.4 淘汰赛 EG vs LGD 第二场
2018/04/05 DOTA
[51:26]VP vs VG 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
python使用matplotlib绘制柱状图教程
2017/02/08 Python
Python3编程实现获取阿里云ECS实例及监控的方法
2017/08/18 Python
分享vim python缩进等一些配置
2018/07/02 Python
python实现指定文件夹下的指定文件移动到指定位置
2018/09/17 Python
Django框架实现的普通登录案例【使用POST方法】
2019/05/15 Python
Python日志处理模块logging用法解析
2020/05/19 Python
一款利用纯css3实现的超炫3D表单的实例教程
2014/12/01 HTML / CSS
C#怎么让一个窗口居中显示?
2015/10/20 面试题
个人查摆剖析材料
2014/02/04 职场文书
公司任命书模板
2014/06/06 职场文书
好听的队名和口号
2014/06/09 职场文书
大学生活动总结模板
2014/07/02 职场文书
升职自我推荐信范文
2015/03/25 职场文书