十个迅速提升十个迅速提升JQuery性能让你的性能让你的JQuery跑得更快跑得更快
本文提供即刻提升你的脚本性能的十个步骤。不用担心,这并不是什么高深的技巧。人人皆可运用!这些技巧包括:
使用最新版本使用最新版本
合并、最小化脚本合并、最小化脚本
用用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++) {
}