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选择器,了解其实现流程是很有必要的,那么这篇文章我就简单的讲讲其实现流程,相信 ...
随机推荐
- 【BZOJ】1051: [HAOI2006]受欢迎的牛(tarjan)
http://www.lydsy.com/JudgeOnline/problem.php?id=1051 这题还好-1A了..但是前提还是看了题解的 囧.....一开始认为是并查集,oh,不行,,无法 ...
- Ubuntu根目录下各文件夹的功能详细介绍
Ubuntu的根目录下存在着很多的文件夹,但你知道他们都存放着哪些文件呢?这些是深入了解Ubuntu系统必不缺少的知识,本文就关于此做一下介绍吧. /bin/ 用以存储二进制可执行命令文件. / ...
- Redis内存存储结构分析
1 Redis 内存存储结构 本文是基于 Redis-v2.2.4 版本进行分析. 1.1 Redis 内存存储总体结构 Redis 是支持多key-value数据库(表)的,并用 RedisDb 来 ...
- 使用mybatis执行oracle存储过程
存储过程在小公司用的不多,但是如果业务比较复杂或者性能要求比较苛刻的时候存储过程就派上用场了,ibatis的前期的一些版本貌似不支持存储过程因此我选择了mybatis来做实验. 1.无输入和输出参数的 ...
- python 操作mysql
安装模块: #pip install .... MySQLdb(2.x) pymysql(3.x) import MySQLdb as sql con = sql.connect( host = &q ...
- python中的list的方法
list1=[1,3,5,"a"]print(dir(list1)) """ ['__add__', '__class__', '__contains ...
- Qt中QUdpSocket序列化问题
写了一个小的Qt网络程序,很简单,发送的网络消息除了字符串还有一个结构体.很简单的想到用memcpy()函数来将数据序列化为BYTE数组从而实现网络传输. 序列化是Java中一个概念,C中并没有,C+ ...
- .net 开发的奇淫巧计
随机数 Random random = new Random(( int)DateTime .Now.Ticks & 0x0000FFFF); 如何让ASP.NET Web API显示完整的错 ...
- MATLAB的使用总结
Log scale %# some random data x = .^(:); y = rand(size(x)); plot(log2(x), y) %# plot on log2 x-scale ...
- linux下IPTABLES配置
如果你的IPTABLES基础知识还不了解,建议先去看看. 开始配置 我们来配置一个filter表的防火墙. (1)查看本机关于IPTABLES的设置情况 [root@tp ~]# iptables - ...