再谈querySelector和querySelectorAll的区别与联系
区别 联系 再谈 querySelector querySelectorAll
2023-06-13 09:14:33 时间
先按W3C的规范来说这两个方法应该返回的内容吧:
querySelector:
returnthefirstmatchingElementnodewithinthenode"ssubtrees.Ifthereisnosuchnode,themethodmustreturnnull.(返回指定元素节点的子树中匹配selector的集合中的第一个,如果没有匹配,返回null)
querySelectorAll:
returnaNodeListcontainingallofthematchingElementnodeswithinthenode"ssubtrees,indocumentorder.Iftherearenosuchnodes,themethodmustreturnanemptyNodeList.(返回指定元素节点的子树中匹配selector的节点集合,采用的是深度优先预查找;如果没有匹配的,这个方法返回空集合)
使用方法:
复制代码代码如下:
querySelector:
returnthefirstmatchingElementnodewithinthenode"ssubtrees.Ifthereisnosuchnode,themethodmustreturnnull.(返回指定元素节点的子树中匹配selector的集合中的第一个,如果没有匹配,返回null)
querySelectorAll:
returnaNodeListcontainingallofthematchingElementnodeswithinthenode"ssubtrees,indocumentorder.Iftherearenosuchnodes,themethodmustreturnanemptyNodeList.(返回指定元素节点的子树中匹配selector的节点集合,采用的是深度优先预查找;如果没有匹配的,这个方法返回空集合)
使用方法:
varelement=baseElement.querySelector(selectors);
varelementList=baseElement.querySelectorAll(selectors);
这在BaseElement为document的时候,没有什么问题,各浏览器的实现基本一致;但是,当BaseElement为一个普通的domNode的时候(支持这两个方法的domNode),浏览器的实现就有点奇怪了,举个例子:
<divclass="test"id="testId">
<p><span>Test</span></p>
</div>
<scripttype="text/javascript">
vartestElement=document.getElementById("testId");
varelement=testElement.querySelector(".testspan");
varelementList=document.querySelectorAll(".testspan");
console.log(element);//<span>Test</span>
console.log(elementList);//1
</script>
按照W3C的来理解,这个例子应该返回:element:null;elementList:[];因为作为baseElement的testElement里面根本没有符合selectors的匹配子节点;但浏览器却好像无视了baseElement,只在乎selectors,也就是说此时baseElement近乎document;这和我们的预期结果不合,也许随着浏览器的不断升级,这个问题会得到统一口径!
人的智慧总是无穷的,AndrewDupont发明了一种方法暂时修正了这个怪问题,就是在selectors前面指定baseElement的id,限制匹配的范围;这个方法被广泛的应用在各大流行框架中;
Jquery的实现:
varoldContext=context,
old=context.getAttribute("id"),<BR>nid=old||id,
try{
if(!relativeHierarchySelector||hasParent){
returnmakeArray(context.querySelectorAll("[id=""+nid+""]"+query),extra);
}
}catch(pseudoError){}<BR>finally{
if(!old){oldContext.removeAttribute("id");}
}
先不看这点代码中其他的地方,只看他如何实现这个方法的;这点代码是JQuery1.6的片段;当baseElement没有ID的时候,给他设置一个id="__sizzle__”,然后再使用的时候加在selectors的前面,做到范围限制;context.querySelectorAll("[id=""+nid+""]"+query;最后,因为这个ID本身不是baseElement应该有的,所以,还需要移除:oldContext.removeAttribute("id");
,Mootools的实现:
varcurrentId=_context.getAttribute("id"),slickid="slickid__";
_context.setAttribute("id",slickid);
_expression="#"+slickid+""+_expression;
context=_context.parentNode;
Mootools和Jquery类似:只不过slickid="slickid__";其实意义是一样的;
方法兼容性:FF3.5+/IE8+/Chrome1+/opera10+/Safari3.2+;
IE8:不支持baseElement为object;
非常感谢大牛JK的回复,提供了另外一种方法。
相关文章
- 特斯拉AI总监:我复现了LeCun 33年前的神经网络,发现和现在区别不大
- Kafuka面试(整合Kafka两种模式区别)
- 深究递归和迭代的区别、联系、优缺点及实例对比「建议收藏」
- Flume和Kafka的区别与联系「建议收藏」
- 数据库和数据仓库的区别与联系_大数据的四个特点
- 取反!和按位取反~的区别[通俗易懂]
- cs和bs比较_cs和bs的区别与联系
- 转发和重定向的区别和使用特点_转发与重定向的联系
- C语言和C++的区别和联系
- TCP/IP、HTTP、Socket之间的区别和联系
- ognl和el表达式有什么区别-struts2 调用OGNL表达式使用方法(EL废弃)
- 普通人和优秀人解决问题的区别是什么?
- PHP cURL 超时设置 CURLOPT_CONNECTTIMEOUT 和 CURLOPT_TIMEOUT 的区别
- java 标准输出与标准错误 out与 err 区别 用法 联系 java中的out与err区别 System.out和System.err的区别 System.out.println和System.err.println的区别 Java重定向System.out和System.err详解编程语言
- Python 之 raw_input()与input()区别详解编程语言
- jQuery 触发事件 移动端和pc端的区别详解编程语言
- 比较Redis和SQL:区别与联系(redissql)
- Linux Shell脚本中单引号(‘)和双引号(“)的区别
- 比较Hive与MySQL的区别与联系(hive与mysql)
- Linux与Windows: 抉择难题(linux与windows区别)
- 基于c#类、接口、结构的联系与区别详解
- jquery中html、val与text三者属性取值的联系与区别介绍