源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

jQuery 性能优化指南(3)

  • 时间:2022-01-20 05:06 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:jQuery 性能优化指南(3)
[b]8,尽量使用ID代替Class。[/b]
 
前面性能优化已经说过,ID选择器的速度是最快的。所以在HTML代码中,能使用ID的尽量使用ID来代替class。 看下面的一个例子: [quote]
// 创建一个list
var $myList = $('#myList');
var myListItems = '<ul>';
for (i = 0; i < 1000; i++) {
     myListItems += '<li class="listItem' + i + '">This is a list item</li>'; //这里使用的是class
 }
myListItems += '</ul>';
$myList.html(myListItems);
// 选择每一个 li
 for (i = 0; i < 1000; i++) {
    var selectedItem = $('.listItem' + i);
}
[/quote] 在代码最后,选择每个li的过程中,总共用了5066毫秒,超过5秒了。 接着我们做一个对比,用ID代替class:   [quote]
// 创建一个list
var $myList = $('#myList');
var myListItems = '<ul>';
for (i = 0; i < 1000; i++) {
    myListItems += '<li id="listItem' + i + '">This is a list item</li>'; //这里使用的是id
}
myListItems += '</ul>';
$myList.html(myListItems);
 // 选择每一个 li
for (i = 0; i < 1000; i++) {
     var selectedItem = $('#listItem' + i);
}
[/quote]
在上段代码中,选择每个li总共只用了61毫秒,相比class的方式,将近快了100倍。
 
 
 
[b]9,给选择器一个上下文[/b]
 
jQuery选择器中有一个这样的选择器,它能指定上下文。 jQuery( expression, context );
通过它,能缩小选择器在DOM中搜索的范围,达到节省时间,提高效率。 普通方式: $('.myDiv') 改进方式: $('.myDiv' , $("#listItem") )
 
 
[b]10,慎用 .live()方法(应该说尽量不要使用)[/b]
 
这是jQuery1.3.1版本之后增加的方法,这个方法的功能就是为 新增的DOM元素 动态绑定事件。 但对于效率来说,这个方法比较占用资源。所以请尽量不要使用它。 例如有这么一段代码: [quote]
<script type="text/javascript" >
$(function(){
 $("p").click(function(){
     alert( $(this).text() );
 });
$("button").click(function(){
    $("<p>this is second p</p>").appendTo("body");
});
}) </script>
<body>
<p>this is first p</p> <button>add</button>
</body>
[/quote] 运行后,你会发现 新增 的 p元素,并没用被绑定click事件。 你可以改成.live("click")方式解决此问题,代码如下: [quote]
$(function(){
$("p").live("click",function(){ //改成live方式
     alert( $(this).text() );
 });
$("button").click(function(){ $("<p>this is second p</p>").appendTo("body"); });})
[/quote] 但我并不建议大家这么做,我想用另一种方式去解决这个问题,代码如下: [quote]
$(function(){
$("p").click(function(){
    alert( $(this).text() );
});
$("button").click(function(){
    $("<p>this is second p</p>").click(function(){  //为新增的元素重新绑定一次
            alert( $(this).text() );
    }).appendTo("body");
});
})
[/quote] 虽然我把绑定事件重新写了一次,代码多了点,但这种方式的效率明显高于live()方式, 特别是在频繁的DOM操作中,这点非常明显。
  [b]11,子选择器和后代选择器[/b]   后代选择器经常用到,比如:$("#list  p"); 后代选择器获取的是元素内部所有元素。 而有时候实际只要获取 子元素,那么就不应该使用后代选择器。 应该使用子选择器,代码如下: $("#list > p");     [b]12,使用data()方法存储临时变量[/b]   下面是一段非常简单的代码, [quote] $(function(){     var flag = false;     $("button").click(function(){         if(flag){             $("p").text("true");             flag=false;         }else{             $("p").text("false");             flag=true;         }     }); }) [/quote]   改用data()方式后,代码如下: [quote] $(function(){     $("button").click(function(){         if( $("p").data("flag") ){             $("p").text("true");             $("p").data("flag",false);         }else{              $("p").text("false");              $("p").data("flag",true);         }     }); }) [/quote]  
jQuery性能优化指南(3)到此结束。
 
相信你也有你的idea,请共享出来吧。 Email : cssrain@gmail.com
[url=http://www.cssrain.cn/][/url] 
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部