JQuery - select class 或是select id?
来源:互联网 发布:网络运营者应当为 编辑:程序博客网 时间:2024/05/21 18:30
$("#someid")$(".someclass")$("[someattr='value']")
这三种选择那个才是最高效的?
ID查询肯定是最快的,部分原因是因为ID是唯一的,当在DOM中找到ID时API会自动停止继续查询。
如果必须使用class选择器的话,可以通过自定可选的上下文参数来提高效率。
$(".someclass", "#somecontainer")
$("#someid .someclass")当时不同浏览器的运行效果却是不同的,下面是运行效果:
IE9
$(".someclass")
- 2793 ms
$(".someclass", "#somecontainer")
- 1481 ms
Chrome 12
$(".someclass")
- 75 ms
$(".someclass", "#somecontainer")
- 104 ms
Firefox 3.6
$(".someclass")
- 308 ms
$(".someclass", "#somecontainer")
- 357 ms
So among these big 3 modern browsers, the context parameter only seems to help IE9. Older browsers will also benefit from the context parameter. But considering the prevalence of each of these browsers and averaging everything out, the net gain is somewhat of a wash now.
And here's the code in case anyone wants to try it themselves...
<html> <head> <script type="text/javascript" src="http://code.jquery.com/jquery-1.6.1.min.js"></script> <script type="text/javascript"> $(document).ready(function(){ startTime = new Date().getTime(); for (i = 0; i < 10000; i++) { s = $(".someclass"); } $("#withoutcontext").html(elapsedMilliseconds(startTime)); startTime = new Date().getTime(); for (i = 0; i < 10000; i++) { s = $(".someclass", "#somecontainer"); } $("#withcontext").html(elapsedMilliseconds(startTime)); }); function elapsedMilliseconds(startTime) { var n = new Date(); var s = n.getTime(); var diff = s - startTime; return diff; } </script> </head> <body> <h1>jQuery Selector Performance: Context vs No Context</h1> <h2>$(".someclass")</h2> <span id="withoutcontext">---</span> ms<br /><br /> <h2>$(".someclass", "#somecontainer")</h2> <span id="withcontext">---</span> ms<br /><br /> <hr /> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <div id="somecontainer"> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="someclass">someclass</p> </div> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> <p class="a">a</p> <p class="b">b</p> <p class="c">c</p> </body></html>
0 0
- JQuery - select class 或是select id?
- 用JQuery设置select标签或是DropList的<open>值
- Jquery <select></select>
- Jquery,Select
- jquery select
- jquery select
- jquery select
- jquery select
- jQuery 根据ID,获取input/checkbox/radio/select
- JQuery $("#id").val(value); 给select选值不出现问题
- SELECT sysobjects.id objectId,
- select by id
- select max(id)优化
- rails select添加class
- select()
- select
- select
- select
- 满秩分解
- Android大图片裁剪解决方案
- Truncate Table 会不会释放索引
- 如何配置outlook邮箱-以Outlook 2013配置QQ邮箱为例
- 遍历propertys
- JQuery - select class 或是select id?
- 事务
- 南大软院大神养成计划——CSS进阶
- JAVA进程间的通信方式(IPC)
- angular js轮播图 (Carousel (ui.bootstrap.carousel))
- mfs(二)--维护
- C++primer plus第六版课后编程练习答案3.3
- Mysql导出表结构及表数据 mysqldump用法
- 商场地图api通过城市ID获取商场列表