提升jQuery的性能需要做好七件事


Posted in Javascript onJanuary 11, 2016

做好七件事帮你提升jQuery的性能,想知道哪几件事情吗?

1. Append Outside of Loops

凡是触及到DOM都是有代价的。如果你向DOM当中附加大量的元素,你会想一次性将它们全部附加进来,而不是分多次进行。当在循环当中附加元素就会产生一个常见的问题。

$.each( myArray, function( i, item ) {

  var newListItem = "<li>" + item + "</li>";
 
 $( "#ballers" ).append( newListItem );
 });

一个常用的技巧是利用文档片段(document fragment)。在循环的每一次迭代当中,将元素附加到片段而不是DOM元素当中。当循环结束后,将片段附加到DOM元素当中即可。

var frag = document.createDocumentFragment();

$.each( myArray, function( i, item ) {

  var newListItem = document.createElement( "li" );
  var itemText = document.createTextNode( item );

  newListItem.appendChild( itemText );

  frag.appendChild( newListItem );

});

$( "#ballers" )[ 0 ].appendChild( frag );

另一个简单的技巧是在循环的每次迭代当中,持续构建一个字符串。当循环结束后,将DOM元素的HTML设置成该字符串。

var myHtml = "";

$.each( myArray, function( i, item ) {

  myHtml += "<li>" + item + "</li>";

});

$( "#ballers" ).html( myHtml );

当然还有其它一些技巧可以供你尝试。一个名为 jsperf 的站点为测试这些性能提供了一条好的出路。该网站允许你使用基准测试每一个技巧,并将其跨平台的性能测试结果可视化的展现出来。

2. Cache Length During Loops

在for循环当中,不要每次都访问数组的 length 属性;应当事先将其缓存起来。

var myLength = myArray.length;

for ( var i = 0; i < myLength; i++ ) {

  // do stuff

}

3. Detach Elements to Work with Them

操作DOM是缓慢的,因此你想尽可能减少对齐进行操作。jQuery在1.4版本当中引入了名为 detach() 的方法来帮助解决这一问题,它允许你在对元素进行操作时,将它们从DOM当中分离出来。

var $table = $( "#myTable" );
var $parent = $table.parent();

$table.detach();

// ... add lots and lots of rows to table

$parent.append( $table );

4. Don't Act on Absent Elements

如果你正打算在一个空的选择器上运行大量的代码,jQuery并不会给予任何的提示 -- 它将会继续的执行,就像是没有发生任何的错误。必须由你来验证选择器包含了多少元素。

// Bad: This runs three functions before it
// realizes there's nothing in the selection
$( "#nosuchthing" ).slideUp();

// Better:
var $mySelection = $( "#nosuchthing" );

if ( $mySelection.length ) {

  $mySelection.slideUp();

}

// Best: Add a doOnce plugin.
jQuery.fn.doOnce = function( func ) {

  this.length && func.apply( this );

  return this;

}

$( "li.cartitems" ).doOnce(function() {


  // make it ajax! \o/


});

本指南特别适用于那些当选择器不包含元素时还需要大量的开销的 jQuery UI 部件。

5. Optimize Selectors

选择器的优化和过去比起来并不是那么的重要,因为很多浏览器都实现了 document.querySelectorAll() 方法并且jQuery将选择器的负担转移到了浏览器上面。但是仍然有一些技巧需要铭记在心。

基于ID的选择器

以一个ID作为选择器的开始总是最好的。

// Fast:
 $( "#container div.robotarm" );
 
 // Super-fast:
 $( "#container" ).find( "div.robotarm" );

采用 .find() 方法的方式将更加的快速,因为第一个选择器已经过处理,而无需通过嘈杂的选择器引擎 -- ID-Only的选择器已使用 document.getElementById() 方法进行处理,之所以快速,是因为它是浏览器的原生方法。

特异性

尽量详细的描述选择器的右侧,对于左侧则应反其道而行之。

// Unoptimized:
$( "div.data .gonzalez" );
 
// Optimized:
 $( ".data td.gonzalez" );

尽量在选择器的最右侧使用 tag.class 的形式来描述选择器,而在左侧则尽量只使用 tag 或者 .class 。

避免过度使用特异性

$( ".data table.attendees td.gonzalez" );
 
 // Better: Drop the middle if possible.
 $( ".data td.gonzalez" );

去讨好“DOM”总是有利于提升选择器的性能,因为选择器引擎在搜寻元素时无需进行太多的遍历。

避免使用通用选择器

如果一个选择器明确或暗示它能在不确定的范围内进行匹配将会大大影响性能。

$( ".buttons > *" ); // Extremely expensive.
$( ".buttons" ).children(); // Much better.
 
 $( ".category :radio" ); // Implied universal selection.
$( ".category *:radio" ); // Same thing, explicit now.
$( ".category input:radio" ); // Much better.
复制代码
6. Use Stylesheets for Changing CSS on Many Elements

假如你使用 .css() 方法来改变超过20个元素的CSS,应当考虑为页面添加一个样式标签作为替代,这样做可以提升将近60%的速度。

// Fine for up to 20 elements, slow after that:
$( "a.swedberg" ).css( "color", "#0769ad" );

// Much faster:
$( "<style type=\"text/css\">a.swedberg { color: #0769ad }</style>")
  .appendTo( "head" );

7. Don't Treat jQuery as a Black Box

以上就是提升jQuery的性能需要做好的七件事,清楚了吧!

Javascript 相关文章推荐
css把超出的部分显示为省略号的方法兼容火狐
Jul 23 Javascript
javascript vvorld 在线加密破解方法
Nov 13 Javascript
jQuery总体架构的理解分析
Mar 07 Javascript
javascript屏蔽右键代码
May 15 Javascript
Egret引擎开发指南之视觉编程
Sep 03 Javascript
url传递的参数值中包含&amp;时,url自动截断问题的解决方法
Aug 02 Javascript
使用jQuery的toggle()方法对HTML标签进行显示、隐藏的方法(示例)
Sep 01 Javascript
node.js+express+mySQL+ejs+bootstrop实现网站登录注册功能
Jan 12 Javascript
详解js跨域请求的两种方式,支持post请求
May 05 Javascript
2020京东618叠蛋糕js脚本(亲测好用)
Jun 02 Javascript
详解JavaScript 异步编程
Jul 13 Javascript
原生js实现点击按钮复制内容到剪切板
Nov 19 Javascript
jQuery 移动端artEditor富文本编辑器
Jan 11 #Javascript
AngularJs动态加载模块和依赖注入详解
Jan 11 #Javascript
jquery在ie7下选择器的问题导致append失效的解决方法
Jan 10 #Javascript
基于Node.js的强大爬虫 能直接发布抓取的文章哦
Jan 10 #Javascript
JavaScript基础知识及常用方法总结
Jan 10 #Javascript
jQuery实现的调整表格行tr上下顺序
Jan 10 #Javascript
javascript实现checkbox复选框实例代码
Jan 10 #Javascript
You might like
PHP中filter函数校验数据的方法详解
2015/07/31 PHP
Ecshop 后台添加新功能栏目及管理权限设置教程
2017/11/21 PHP
PHP读取Excel内的图片(phpspreadsheet和PHPExcel扩展库)
2019/11/19 PHP
javascript对象之内置对象Math使用方法
2010/04/16 Javascript
jquery 插件学习(一)
2012/08/06 Javascript
jQuery页面图片伴随滚动条逐渐显示的小例子
2013/03/21 Javascript
JS将光标聚焦在文本最后的实现代码
2014/03/28 Javascript
JavaScript转换二进制编码为ASCII码的方法
2015/04/16 Javascript
AngularJS模块管理问题的非常规处理方法
2015/04/29 Javascript
JavaScript中三个等号和两个等号你了解多少
2017/07/04 Javascript
微信小程序实现tab和swiper切换结合效果
2020/07/17 Javascript
vue单页应用在页面刷新时保留状态数据的方法
2018/09/21 Javascript
JS扁平化输出数组的2种方法解析
2019/09/17 Javascript
让mocha支持ES6模块的方法实现
2020/01/14 Javascript
js实现视图和数据双向绑定的方法分析
2020/02/05 Javascript
Vue快速实现通用表单验证的方法
2020/02/24 Javascript
基于JavaScript实现控制下拉列表
2020/05/08 Javascript
Openlayers实现距离面积测量
2020/09/28 Javascript
python列表与元组详解实例
2013/11/01 Python
python3.6使用tkinter实现弹跳小球游戏
2019/05/09 Python
用pycharm开发django项目示例代码
2019/06/13 Python
django 中的聚合函数,分组函数,F 查询,Q查询
2019/07/25 Python
深入浅析Python 中的sklearn模型选择
2019/10/12 Python
Python银行系统实战源码
2019/10/25 Python
在jupyter notebook中调用.ipynb文件方式
2020/04/14 Python
Python应用实现双指数函数及拟合代码实例
2020/06/19 Python
基于python实现删除指定文件类型
2020/07/21 Python
html5 svg 中元素点击事件添加方法
2013/01/16 HTML / CSS
ProBikeKit德国:在线公路自行车专家
2018/06/03 全球购物
军校制空专业毕业生自我鉴定
2013/11/16 职场文书
房产委托公证书样本
2014/04/04 职场文书
党课心得体会范文
2014/09/09 职场文书
四风问题个人对照检查剖析材料
2014/09/27 职场文书
2015年保送生自荐信
2015/03/24 职场文书
汽车修理厂管理制度
2015/08/05 职场文书
CSS3中Animation实现简单的手指点击动画的示例
2021/07/15 HTML / CSS