$('[data-key="vaule"]')
在jQuery中,此类方法相较于id、class在效率上有何区别?
无论什么选择器,美刀这个函数都很重,都应该把结果暂存下来复用
关于选择器本身的速度,理论上来说现代浏览器的情况下(也就是委托给了querySelector的时候)应该是和.class相差无几,如果.class比[attr=val]要快,那应该是浏览器专门为它做了优化。因为本质是一样的(遍历dom树)
其实这个问题应该是用数据说话的。我google了一下jsperf selector attribute vs cssclas果然第一条就是答案。贴个比较新的有点数据的revision
ID最快毫无疑问,然后就是浏览器确实对class做过优化,速度会比attribute快,但和ID没的比
最后要说的是,即使是用ID,美刀这个函数还是相当重,应该把结果暂存下来复用
无论什么选择器,美刀这个函数都很重,都应该把结果暂存下来复用
关于选择器本身的速度,理论上来说现代浏览器的情况下(也就是委托给了querySelector的时候)应该是和.class相差无几,如果.class比[attr=val]要快,那应该是浏览器专门为它做了优化。因为本质是一样的(遍历dom树)
其实这个问题应该是用数据说话的。我google了一下jsperf selector attribute vs cssclas
果然第一条就是答案。贴个比较新的有点数据的revision
ID最快毫无疑问,然后就是浏览器确实对class做过优化,速度会比attribute快,但和ID没的比
最后要说的是,即使是用ID,美刀这个函数还是相当重,应该把结果暂存下来复用
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。