javascript之querySelector和querySelectorAll使用介绍


Posted in Javascript onDecember 20, 2011

一开始很多人都会拿jquery的选择器来跟这两个api做对比(我也是),比较异同本来没事,但却使一些同学对这两个api在浏览器中的实现产生了误解,特别是再dom element上调用此api时。
下面是我的jsFiddle示例,我就以此展开说明:
js代码:

(function(global) { 
global.doc = document; 
global.body = doc.getElementsByTagName('body')[0]; 
global.$ = function(id) { 
return doc.getElementById(id); 
} 
global.Logger = function(id) { 
this.logElem = $(id); 
this.logArr = []; 
}; 
global.Logger.prototype = { 
constructor: global.logger, 
append: function(comment) { 
this.logArr.push('<p>' + comment + '</p>'); 
}, 
flush: function() { 
this.logElem.innerHTML = this.logArr.join(''); 
}, 
clear: function() { 
this.logElem.innerHTML = ''; 
this.logArr = []; 
} 
}; 
})(this); 
(function() { 
var logger = new Logger('log'); 
var items = $('inner').querySelectorAll('#main h4.inside'); 
logger.append(items.length); 
for(var i = 0, len = items.length; i < len; i++) { 
logger.append(items[i].innerHTML); 
} 
logger.flush(); 
})(); 
(function(global) { 
global.doc = document; 
global.body = doc.getElementsByTagName('body')[0]; 
global.$ = function(id) { 
return doc.getElementById(id); 
} 
global.Logger = function(id) { 
this.logElem = $(id); 
this.logArr = []; 
}; 
global.Logger.prototype = { 
constructor: global.logger, 
append: function(comment) { 
this.logArr.push('<p>' + comment + '</p>'); 
}, 
flush: function() { 
this.logElem.innerHTML = this.logArr.join(''); 
}, 
clear: function() { 
this.logElem.innerHTML = ''; 
this.logArr = []; 
} 
}; 
})(this); 
(function() { 
var logger = new Logger('log'); 
var items = $('inner').querySelectorAll('#main h4.inside'); 
logger.append(items.length); 
for(var i = 0, len = items.length; i < len; i++) { 
logger.append(items[i].innerHTML); 
} 
logger.flush(); 
})();

html代码:

<div id="main"> 
<div id="inner"> 
<h4 class="inside">h4 inside 1</h4> 
<h4 class="inside">h4 inside 2</h4> 
<ul class="nodelist"> 
<li>list item one</li> 
<li>list item two</li> 
<li>list itme three</li> 
</ul> 
</div> 
<div id="outter"> 
<h4 class="outside">h4 outside 1</h4> 
<h4 class="outside">h4 outside 2</h4> 
</div> 
<div id="log"></div>

css代码:

#log { 
font-size: 10px; 
}

误解就在于对$('inner').querySelectorAll('#main h4.inside')的实现理解,不少人一开始几乎都认为是直接从div[id='inner']的孩子中进行查找(我也是),这个#main有点碍眼。实际上它还是根据selector string从整个document上查找,再返回属于div[id='inner']的子节点。很多人会疑惑,那么为什么不按照直接按父节点找子节点的方式来实现呢?就像elem.getElementsByTagName,我的想法是灵活selector string吧。

querySelector只返回匹配的第一个元素,如果没有匹配项,返回null。
querySelectorAll返回匹配的元素集合,如果没有匹配项,返回空的nodelist(节点数组)。

并且返回的结果是静态的,之后对document结构的改变不会影响到之前取到的结果。
目前IE8+,ff,chrome都支持此api(IE8中的selector string只支持css2.1的)。

Javascript 相关文章推荐
两个SUBMIT按钮,如何区分处理
Aug 22 Javascript
javascript一点特殊用法
May 28 Javascript
Jquery 实现Tab效果 思路是js思路
Mar 02 Javascript
基于jquery的让页面控件不可用的实现代码
Apr 27 Javascript
无阻塞加载脚本分析[全]
Jan 20 Javascript
juqery 学习之五 文档处理 包裹、替换、删除、复制
Feb 11 Javascript
javascript实现动态加载CSS
Jan 26 Javascript
js中new一个对象的过程
Feb 20 Javascript
AngulaJS路由 ui-router 传参实例
Apr 28 Javascript
node.js的exports、module.exports与ES6的export、export default深入详解
Oct 26 Javascript
详解vue 命名视图
Aug 14 Javascript
原生js+canvas实现下雪效果
Aug 02 Javascript
js有关元素内容操作小结
Dec 20 #Javascript
js汉字排序问题 支持中英文混排,兼容各浏览器,包括CHROME
Dec 20 #Javascript
suggestion开发小结以及对键盘事件的总结(针对中文输入法状态)
Dec 20 #Javascript
js change,propertychange,input事件小议
Dec 20 #Javascript
JavaScript面向对象设计二 构造函数模式
Dec 20 #Javascript
Javascript面向对象设计一 工厂模式
Dec 20 #Javascript
用JavaScript仿PS里的羽化效果代码
Dec 20 #Javascript
You might like
php foreach、while性能比较
2009/10/15 PHP
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
2012/06/17 PHP
php删除文件夹及其文件夹下所有文件的函数代码
2013/01/23 PHP
joomla组件开发入门教程
2016/05/04 PHP
CI框架扩展系统核心类的方法分析
2016/05/23 PHP
PHP 自动加载类原理与用法实例分析
2020/04/14 PHP
Mootools 1.2教程 同时进行多个形变动画
2009/09/15 Javascript
js实现简单的可切换选项卡效果
2015/04/10 Javascript
drag-and-drop实现图片浏览器预览
2015/08/06 Javascript
基于nodejs+express(4.x+)实现文件上传功能
2015/11/23 NodeJs
Bootstrap路径导航与分页学习使用
2017/02/08 Javascript
微信小程序解除10个请求并发限制
2018/12/18 Javascript
JavaScript多种滤镜算法实现代码实例
2019/12/10 Javascript
vue+canvas实现移动端手写签名
2020/05/21 Javascript
微信公众号网页分享功能开发的示例代码
2020/05/27 Javascript
[16:19]教你分分钟做大人——风暴之灵
2015/03/11 DOTA
对python numpy数组中冒号的使用方法详解
2018/04/17 Python
python多线程并发让两个LED同时亮的方法
2019/02/18 Python
Python面向对象程序设计之私有属性及私有方法示例
2019/04/08 Python
python 发送json数据操作实例分析
2019/10/15 Python
基于Python检测动态物体颜色过程解析
2019/12/04 Python
解析pip安装第三方库但PyCharm中却无法识别的问题及PyCharm安装第三方库的方法教程
2020/03/10 Python
Python利用PyPDF2库获取PDF文件总页码实例
2020/04/03 Python
Python2手动安装更新pip过程实例解析
2020/07/16 Python
Python加速程序运行的方法
2020/07/29 Python
顶级宝石首饰网络零售商:Angara
2016/10/25 全球购物
法院四风对照检查材料思想汇报
2014/10/06 职场文书
保密工作整改报告
2014/11/06 职场文书
2014年审计人员工作总结
2014/12/19 职场文书
岗位职责范本大全
2015/02/26 职场文书
法律意见书范本
2015/06/04 职场文书
参观监狱警示教育心得体会
2016/01/15 职场文书
2016年敬老月活动总结
2016/04/05 职场文书
使用这 6个Vue加载动画库来减少我们网站的跳出率
2021/05/18 Vue.js
8g内存用python读取10文件_面试题-python 如何读取一个大于 10G 的txt文件?
2021/05/28 Python
Mybatis-Plus 使用 @TableField 自动填充日期
2022/04/26 Java/Android