时间:2021-05-26
8,尽量使用ID代替Class。
前面性能优化已经说过,ID选择器的速度是最快的。所以在HTML代码中,能使用ID的尽量使用ID来代替class。
看下面的一个例子:
在代码最后,选择每个li的过程中,总共用了5066毫秒,超过5秒了。
接着我们做一个对比,用ID代替class:
// 创建一个listvar $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); } 在上段代码中,选择每个li总共只用了61毫秒,相比class的方式,将近快了100倍。9,给选择器一个上下文jQuery选择器中有一个这样的选择器,它能指定上下文。
jQuery( expression, context );
这是jQuery1.3.1版本之后增加的方法,这个方法的功能就是为 新增的DOM元素 动态绑定事件。
但对于效率来说,这个方法比较占用资源。所以请尽量不要使用它。
例如有这么一段代码:
运行后,你会发现 新增 的 p元素,并没用被绑定click事件。
你可以改成.live("click")方式解决此问题,代码如下:
但我并不建议大家这么做,我想用另一种方式去解决这个问题,代码如下:
虽然我把绑定事件重新写了一次,代码多了点,但这种方式的效率明显高于live()方式,
特别是在频繁的DOM操作中,这点非常明显。
11,子选择器和后代选择器
后代选择器经常用到,比如:$("#list p");
后代选择器获取的是元素内部所有元素。
而有时候实际只要获取 子元素,那么就不应该使用后代选择器。
应该使用子选择器,代码如下:
$("#list > p");
12,使用data()方法存储临时变量
下面是一段非常简单的代码,
$(function(){
var flag = false;
$("button").click(function(){
if(flag){
$("p").text("true");
flag=false;
}else{
$("p").text("false");
flag=true;
}
});
})
改用data()方式后,代码如下:
$(function(){
$("button").click(function(){
if( $("p").data("flag") ){
$("p").text("true");
$("p").data("flag",false);
}else{
$("p").text("false");
$("p").data("flag",true);
}
});
})
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
jQuery入门指南教程这个指南是一个对jQuery库的说明,要求读者了解HTML(DOM)和CSS的一些常识。它包括了一个简单的HelloWorld的例子,选
《高性能网站建设指南》这本书里为Web性能提升设置了14条规则:1.尽量减少HTTP请求2.使用CDN3.添加Expires头4.采用Gzip压缩组件5.将样式
《jQuery权威指南》第1章jQuery开发入门,本章通过循续渐进的方式,先从jQuery的基础概念入手,介绍jQuery库的下载,引入简单应用方法;后部分侧
本文较为详细分析了jQuery性能优化技巧。分享给大家供大家参考。具体分析如下:一、使用最新版本的jQuery类库jQuery新版本会较上个版本进行Bug修复和
1.ID规则2.Class规则3.标签规则4.通用规则对效率的普遍认识是从SteveSouders在2009年出版的《高性能网站建设进阶指南》开始,虽然该书中罗