博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何循环遍历document.querySelectorAll()方法返回的结果
阅读量:6720 次
发布时间:2019-06-25

本文共 1455 字,大约阅读时间需要 4 分钟。

使用JavaScript的forEach方法,我们可以轻松的循环一个数组,但如果你认为document.querySelectorAll()方法返回的应该是个数组,而使用forEach循环它:

/* Will Not Work */document.querySelectorAll('.module').forEach(function() {  });

  

执行上面的代码,你将会得到执行错误的异常信息。这是因为,document.querySelectorAll()返回的不是一个数组,而是一个NodeList

对于一个NodeList,我们可以用下面的技巧来循环遍历它:

var divs = document.querySelectorAll('div');[].forEach.call(divs, function(div) {  // do whatever  div.style.color = "red";});

  当然,我们也可以用最传统的方法遍历它:

var divs = document.querySelectorAll('div'), i;for (i = 0; i < divs.length; ++i) {  divs[i].style.color = "green";}

  还有一种更好的方法,就是自己写一个:

 

// forEach method, could be shipped as part of an Object Literal/Modulevar forEach = function (array, callback, scope) {  for (var i = 0; i < array.length; i++) {    callback.call(scope, i, array[i]); // passes back stuff we need  }};// 用法:// optionally change the scope as final parameter too, like ECMA5var myNodeList = document.querySelectorAll('li');forEach(myNodeList, function (index, value) {  console.log(index, value); // passes index + value back!});

  还有一种语法:for..of 循环,但似乎只有Firefox支持:

/* Be warned, this only works in Firefox */var divs = document.querySelectorAll('div );for (var div of divs) {  div.style.color = "blue";}

  最后是一种不推荐的方法:给NodeList扩展一个forEach方法:

NodeList.prototype.forEach = Array.prototype.forEach;var divs = document.querySelectorAll('div').forEach(function(el) {  el.style.color = "orange";})

  

转载于:https://www.cnblogs.com/xupeiyu/p/5067115.html

你可能感兴趣的文章
C#文件、文件夹操作
查看>>
MySQL编译安装加入service
查看>>
以rsync进行同步镜像备份
查看>>
热烈祝贺VMware View4.5荣获“2010年度最佳产品”大奖
查看>>
ORACLE 11G 中表空间传输 TransportableTablespace
查看>>
自动化1
查看>>
Jenkins 2.32.3参数化构建maven项目
查看>>
使用Oracle存储过程批量生成测试数据
查看>>
正则表达式 - ×××
查看>>
Target runtime Apache Tomcat v6.0 is not defined
查看>>
.net密码找回
查看>>
安装mysql遇到的问题
查看>>
我的友情链接
查看>>
大道至简--GoEasy推送
查看>>
免费邮箱服务器(收藏)
查看>>
org.aspectj.lang.JoinPoint-中文简要API
查看>>
数据库内存使用
查看>>
shell-9-函数(tc与限速实例)
查看>>
[战略]Fans未来战略--第4篇--2012年的IT技术学习规划
查看>>
Linux入门之一:LInux系统环境及命令使用
查看>>