jquery选择器效率优化问题
jquery选择器效率优化问题
jquery选择器固然强大,但是使用不当回导致效率问题;
1.要养成将jQuery对象缓存进变量的习惯
//不好的写法
$('#btn').bind("click",function() {});
$('#btn').css("border","1px solid red");
$("#btn").css("background-color","green");
$("#btn").fadeIn("slow")
//正确写法;
var $obj=$("#btn");
$obj.bind("click",function (){});
$obj.css("border","1px solid red");
$obj.css("background-color",'green');
$obj.fadeIn("slow"); //为了区分普通的JavaScript对象和jQuery对象,可以在变量首字母前加上$符号。
//上面代码可以使用jQuery的链式操作加以改善。如下所示:
var $obj=$("#btn");
$obj.bind("click",function (){})
.css("border","1px solid red")
.css("background-color",'green')
.fadeIn("slow");
2.能有id则用id
毫无疑问jq中最快的选择器是id选择器,因为它直接对应着我们的javascript的document.getElementsById();
HTML
<div id="outer">
<div id="inner">
<input type="text" class="txt" />
<input type="button" class="test" id="btn" value="click" />
</div>
</div>
js
//不好的写法
var obj=$("#outer .test");
//直接获取就行了
var obj=$("#btn"); var obj=$("#inner input.txt")
////建议从最近的ID开始继承
var obj=$('input.txt') //不建议使用tag来修饰id 有种化蛇天足的感觉
var obj=$("div#outer");
//或者
var obj=$("#outer#inner");
实例二
html
<ul id="list">
<li class="li0">1</li>
<li class="li1">2</li>
<li class="li2">3</li>
</ul>
<ul id="list1">
<li id="li0">1</li>
<li id="li1">2</li>
<li id="li2">3</li>
</ul>
js
for(var i=0;i<3;i++){
$('.li'+i)
}
//相比之下,还是比较推荐第二种写法
for(var j=0;j<3;j++){
$('#li'+i);
}
ps:也可以给选择器指定一个上下文;
var list=$('.mydiv');
var outer=$('#outer');
var list=$('.mydiv',outer);
3.如果你打算在其他函数中使用jQuery对象,那么你必须把它们缓存到全局环境中
window.$obj={head:$('head'),obj:$('#outer')};
function do_something(){
var script=document.createElement("script");
$obj.head.append(script);
$obj.obj.css("border","1px solid red");
}
//这里的基本思想是在内存中建立你确实想要的东西,然后更新DOM。
//这并不是一个jQuery最佳实践,但必须进行有效的JavaScript操作
//不好的做法;
for(var i=0;i<100;i++){
$("#content").append('<span>index='+i+'</span>');
}
//推荐写法;
var html="";
for(var i=0;i<100;i++){
html+='<span>index='+i+'</span>';
}
$('#content').append(html);
4.我们要为一个拥有很多输入框的表单绑定这样的行为:当输入框被选中时为它添加一个class
除非在特殊情况下,否则每个js事件(click,mouseover)都会冒泡到父级节点,当我们需要给多个元素调用同一个函数时候,
这点可能会有用,代替这种效率很差的多元素监听的方法是:你只需向他们的父节点绑定一次就ok了;
//不好的写法
$("#formId input").bind("focus",function (){
$(this).addClass('selected').bind("blur",function (){
$(this).removeClass('selected');
})
})
//推荐写法;
$("#formId").bind("focus",function (e){
var $cell=$(e.target);
//e.target捕捉到触发的目标元素
$cell.addClass('selected');
}).bind('blur',function (e){
var $cell=$(e.target);
$cell.removeClass('selected'); }); //比如:
$("#mytable td").click(function (){
$(this).css('background','red');
})
//改进方式
$("#mytable").click(function (e){
var $clicked=$(e.target);
$clicked.css('background','red');
})
//总结
//假设有100个td,在使用普通的方式的时候,你绑定了100个事件。在改进方式中,
//你只为一个元素绑定了1个事件,至于是100个事件的效率高,还是1个事件的效率高,
//相信你也能自行分辨了。
5.推迟到 $(window).load
尽管$(document).rady 确实很有用, 它可以在页面渲染时,其它元素还没下载完成就执行。如果你发现你的页面一直是载入中的状态,
很有可能就是$(document).ready函数引起的。你可以通过将jQuery函数绑定到$(window).load 事件的方法来减少页面载入时的cpu使用率。
它会在所有的html(包括<iframe>)被下载完成后执行。
以下是引用片段:
$(window).load(function(){
// 页面完全载入后才初始化的jQuery函数.
});
一些特效的功能,例如拖放,视觉特效和动画,预载入隐藏图像等等,都是适合这种技术的场合。
6.压缩JavaScript
7.10.慎用 .live()方法(应该说尽量不要使用)
jQuery1.3.1版本之后增加的方法,这个方法的功能就是为 新增的DOM元素 动态绑定事件
8.子选择器和后代选择器
$("#outer div"); //后代选择器
$("#outer>div") //子选择器
//应该根据具体的情况来选择使用
9.使用data()方法存储临时变量
//应该根据具体的情况来选择使用
//关于data的使用滴呀
//就能在一个元素上存放任何格式的数据,而不仅仅是字符串
var temp='temp';
var obj={name:'jack',age:18};
var bodyData=$(document.body);
bodyData.data("temp",temp);
bodyData.data("obj",obj);
alert(bodyData.data("temp"));
alert(bodyData.data("obj").name);
//移除data
bodyData.removeData("temp");
bodyData.removeData("obj");
alert(bodyData.data("temp")); //undefined
alert(bodyData.data("obj").name);//undefined
//具体的实例;
var flag=false;
$("#btn").click(function (){
if(flag){
//do xx
flag=false;
}else{
//do yy
flag=true;
}
})
//使用data改进后的代码;
$("#btn").click(function (){
if($('p').data('flag')){
//do xx
$('p'.data('flag',false))
}else{
//do yy
$('p').data('flag',true)
}
})
10.使用toggleClass来优化
//方式一
$("#temp").mouseover(function (){
$(this).addClass('color')
}) $("#temp").mouseout(function (){ $(this).removeClass('color');
}) //方式二
$("#temp").mouseover(function (){
$(this).addClass("color");
}).mouseout(function (){
$(this).removeClass("color");
}) //方式三
$("#temp").hover(function (){
$(this).toggleClass('color');
})
jquery选择器效率优化问题的更多相关文章
- jQuery选择器的优化选择
jQuery选择器的优化选择 1.1 属性选择器 var $div=$("[id]"); 选中拥有该属性的元素 var $div=$("[id=div]"); ...
- jQuery 选择器效率
http://blog.csdn.net/cxl444905143/article/details/48808809 ID > Tag > Class ID 选择器是速度最快的,这主要是因 ...
- jQuery——选择器效率
N1:$('#box').find('p'):最快,直接了当的找到对应的节点jQuery对象: N2:$('p','#box'):注意不是$('p,#box')!!!,jQuery会按照从右往左的顺序 ...
- 优化jQuery选择器
优化jQuery选择器 选择优化比以前更加重要,因为越来越多的浏览器实现了queryselectorall()并承担了将jQuery选择器转移到浏览器的责任.记住这些小技巧可以让你轻松突破学习选择器时 ...
- jQuery选择器的效率问题
jQuery提供了功能强大,并兼容多种css版本的选择器,不过发现很多同学在使用选择器时并未注重效率的问题. a) 尽量使用Id选择器,jQuery选择器使用的API都是基于getElementByI ...
- jQuery高级技巧——性能优化篇
通过CDN(Content Delivery Network)引入jQuery库 要提升网站中javascript的性能的最简单的一步就是引入最新版本的jQuery库,新发布的版本通常在性能上会有 ...
- jQuery 选择器和JavaScript 选择器的技巧与异常原因
jquery的选择器借鉴了css选择器,核心依然依靠JavaScript的getElementById()和getElementsByTagName()方法,但是他封装了2个方法,让jquery选择器 ...
- [转]关于浏览器css选择器性能优化
作为一个前端开发, 我觉得很有必要了解浏览器对css选择器的解析,因为这个关系到页面的渲染,高效的方式.避开开销大的方式这些无疑为网站加载缩短了时间. 最近在新的项目中陷入了一个误区,也是出于对jqu ...
- jquery选择器的实现流程简析及提高性能建议!
当我们洋洋得意的使用jquery强大的选择器功能时有没有在意过jquery的选择性能问题呢,其实要想高效的使用jquery选择器,了解其实现流程是很有必要的,那么这篇文章我就简单的讲讲其实现流程,相信 ...
随机推荐
- wc2016总结
因为我太弱了,高一才第一次来wc. 前几天讲课,被各种小学微积分和初中高等代数虐,简直naive.只好自己做做bzoj,想着练练模板之类的东西. 考试当天自觉状态不错,翻开试题感觉各种神奇(这难道是串 ...
- Mybatis_mybatis常用jdbcType数据类型
MyBatis 通过包含的jdbcType类型 BIT FLOAT CHAR TIMESTAMP OTHER UNDEFINED ...
- Webscan360的防御与绕过
这两天给360做了一个webscan360的总结,结果补丁还没有出来,就被人公布到了91org上面,既然公开了,那我就做一个总结 首先我们贴上它最新的防御正则 \<.+javascript:wi ...
- windows上在linux客户端上传小文件lrzsz
yum install lrzsz 即可 rz上传,会打开本地图形化界面直接上传 基于centos系统,其他系统请找对应 的源码包编译 一下
- mongodb 手动分片的命令汇总
手动分片的操作 自动分片会带来性能的下降. 所以要合理使用手动分片. 并且配合Tag一起使用. # 对于4个shard的程序, 预先处理的指令1. 加入分片服务器sh.addShard( " ...
- java build path->source folder分析
1.build path下的source folde,指的是项目存放源码的位置,即存放Java代码的位置!!! 如果将一个文件夹设为java build path里的source folder下,则这 ...
- mysql读写分离(PHP类)
mysql读写分离(PHP类) 博客分类: php mysql 自己实现了php的读写分离,并且不用修改程序 优点:实现了读写分离,不依赖服务器硬件配置,并且都是可以配置read服务器,无限扩展 ...
- JNDI学习总结(一)——JNDI数据源的配置
一.数据源的由来 在Java开发中,使用JDBC操作数据库的四个步骤如下: ①加载数据库驱动程序(Class.forName("数据库驱动类");) ②连接数据库(Connec ...
- linux C gcc -lm
使用math.h中声明的库函数还有一点特殊之处,gcc命令行必须加-lm选项,因为数学函数位于libm.so库文件中(这些库文件通常位于/lib目录下),-lm选项告诉编译器,我们程序中用到的数学函数 ...
- JS初学者必备的几个经典案例(一)!!!
一:选中复选框按钮可用 和 倒计时10秒后按钮可用 这是倒计时10秒后按钮可用 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 ...