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选择器,了解其实现流程是很有必要的,那么这篇文章我就简单的讲讲其实现流程,相信 ...
随机推荐
- BZOJ3925: [Zjoi2015]地震后的幻想乡
Description 傲娇少女幽香是一个很萌很萌的妹子,而且她非常非常地有爱心,很喜欢为幻想乡的人们做一些自己力所能及的事情来帮助他们. 这不,幻想乡突然发生了地震,所有的道路都崩塌了.现在的首要任 ...
- CMYK印刷色
一,介绍 CMYK也称作印刷色彩模式,顾名思义就是用来印刷的. 它和RGB相比有一个很大的不同:RGB模式是一种发光的色彩模式,CMYK是一种依靠反光的色彩模式. CMYK——即青.洋红(品红).黄. ...
- 用wampserver 装的集成环境,命令行进不去提示mysql
命令行进不去提示mysql 不是内部命令或外部命令. 解决办法,就是将mysql/bin路径加到path中去
- zend framerwork2.X系列安装创建应用
1. 到https://github.com/zendframework/ZendSkeletonApplication下载zip包,解压到你服务器的根目录. 2. 打开windows的cmd,cd到 ...
- LR中的编码问题
[转载]LoadRunner字符集与检查点的探讨 很多人在loadrunner测试脚本中加入中文检查点的时候会出现检查失败的情况,究竟是为什么呢?其实是被测试系统与loadrunner字符集之间的转换 ...
- processor, memory, I/O
COMPUTER ORGANIZATION AND ARCHITECTURE DESIGNING FOR PERFORMANCE NINTH EDITION 3.3 INTERCONNECTION S ...
- ubuntu挂载其他分区到/home下,将当前分区内容替换
有时候,我们装系统时,可能因为没注意,把某一个分区分小了,导致到最后,我们的那个盘容不下了, 这时,面临的两个选择就是:要么卸载一些软件,要么重新分区,重装系统,其实,还可以这样,去把其他 多余的盘分 ...
- setattribute兼容
var spanElement = document.getElementById("mySpan"); spanElement.style.cssText = "fon ...
- JQuery..bind命名空间
先看手册,由于bind方法有三个参数(type,[data],fn),所以手册上这么介绍: .bind() 方法是用于往文档上附加行为的主要方式.所有JavaScript事件对象, 比如focus, ...
- phpcms list页实现分页
{pc:content action="lists" catid="41" order="id ASC" num="1" ...