jQuery性能优化指南[译](3)

作者:Robin 来源:Time Machine 时间:2009-05-12 11:54:00 

5.使用子查询

jQuery 允许我们对一个已包装的对象使用附加的选择器操作. 因为我们已经在保存了一个父级对象在变量里, 这样大大提高对其子元素的操作:

<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_light = $(‘#traffic_light’),
$active_light = $traffic_light.find(‘input.on’),
$inactive_lights = $traffic_light.find(‘input.off’);

提示: 你可以用逗号分隔的方法一次声明多个局部变量–节省字节数


6.对直接的DOM操作进行限制

这里的基本思想是在内存中建立你确实想要的东西,然后更新DOM 。这并不是一个jQuery最佳实践,但必须进行有效的JavaScript操作 。直接的DOM操作速度很慢。

例如,你想动态的创建一组列表元素, 千万不要这么做:

var top_100_list = [...], // 假设这里是100个独一无二的字符串
$mylist = $(‘#mylist’); // jQuery 选择到 <ul> 元素


for (var i=0, l=top_100_list.length; i<l; i++)
{
$mylist.append(‘<li>’ + top_100_list[i] + ‘</li>’);
}

我们应该将整套元素字符串在插入进dom中之前全部创建好:

var top_100_list = [...],
$mylist = $(‘#mylist’),
top_100_li = “”; // 这个变量将用来存储我们的列表元素


for (var i=0, l=top_100_list.length; i<l; i++)
{
top_100_li += ‘<li>’ + top_100_list[i] + ‘</li>’;
}
$mylist.html(top_100_li);

我们在插入之前将多个元素包裹进一个单独的父级节点会更快:

var top_100_list = [...],
$mylist = $(‘#mylist’),
top_100_ul = ‘<ul id=”#mylist”>’;


for (var i=0, l=top_100_list.length; i<l; i++)
{
top_100_ul += ‘<li>’ + top_100_list[i] + ‘</li>’;
}
top_100_ul += ‘</ul>’; //关闭无序列表
$mylist.replaceWith(top_100_ul);

如果你做了以上几条还是担心有性能问题,那么:

  • 试试jquery的 clone() 方法, 它会创建一个节点树的副本, 它允许以”离线”的方式进行dom操作, 当你操作完成后再将其放回到节点树里.

  • 使用DOM DocumentFragments. 正如jQuery作者所言, 它的性能要明显优于直接的dom操作.

标签:javascript,jquery,性能
0
投稿

猜你喜欢

  • JavaScript判断对象和数组的两种方法

    2024-04-16 08:58:34
  • Golang如何交叉编译各个平台的二进制文件详解

    2024-05-22 17:48:47
  • 重新restore了mysql到另一台机器上后mysql 编码问题报错

    2024-01-24 05:10:41
  • Pandas常用累计、同比、环比等统计方法实践过程

    2021-03-13 01:48:36
  • Python中的jquery PyQuery库使用小结

    2023-05-27 11:08:15
  • Python使用cx_Oracle调用Oracle存储过程的方法示例

    2021-01-26 19:37:28
  • SQL语句单引号与双引号的使用方法

    2024-01-22 11:35:09
  • javascript彩虹圈效果

    2011-08-05 19:10:45
  • 基于Opencv图像识别实现答题卡识别示例详解

    2023-05-18 20:32:50
  • ExecuteReader(),ExecuteNonQuery(),ExecuteScalar(),ExecuteXmlReader()之间的区别

    2023-07-08 23:15:54
  • 最新Adobe 2022全新上线 Adobe 2022永久免费使用教程

    2022-02-01 14:59:07
  • Linux下Resin+JSP+MySQL安装和配置

    2009-09-01 10:38:00
  • javascript demo 基本技巧

    2024-04-29 13:24:45
  • php获取文件扩展名的3种方法实例

    2023-05-25 02:15:51
  • Python如何查看两个数据库的同名表的字段名差异

    2024-01-25 04:37:57
  • Elasticsearch索引的分片分配Recovery使用讲解

    2022-03-25 18:00:18
  • Node.js中的process.nextTick使用实例

    2024-05-08 09:36:18
  • python实现五子棋小游戏

    2023-02-28 08:37:59
  • vue 解决兄弟组件、跨组件深层次的通信操作

    2024-05-09 15:12:55
  • 浅析SQL数据操作语句

    2024-01-12 21:56:13
  • asp之家 网络编程 m.aspxhome.com