JavaScript 中有哪些遍历方式?

本贴最后更新于 3292 天前,其中的信息可能已经时过境迁

不管是移动移动端开发还是 web 端开发,我们对 JS 的使用频率都在增加,今天小编将要和大家分享的就是 JavaScript 中,遍历方式的一些实现方法,个人感觉还是很有用的,有兴趣的童鞋可以一起来看看。

   为了让大家更直观的了解相关功能,本文将通过例子向大家展示JavaScript的各种遍历,为了方便展示,我们先来了解一下现有数组和json对象:

var demoArr = ['Javascript', 'Gulp', 'CSS3', 'Grunt', 'jQuery', 'angular'];

var demoObj = {

aaa: 'Javascript',

bbb: 'Gulp',

ccc: 'CSS3',

ddd: 'Grunt',

eee: 'jQuery',

fff: 'angular'

};

For 循环

For 循环是编程语言中常用的循环,具体的就不介绍了,直接看实例:

(function() {

for(var i=0, len=demoArr.length; i<len; i++) {

if (i == 2) {

  // return;   // 函数执行被终止
  
  // break;	// 循环被终止
  
  continue; // 循环被跳过
  
};

console.log('demo1Arr['+ i +']:' + demo1Arr[i]);

}

})();

虽然 for 循环的使用频率很高,但是还是不得不提醒大家以下几点注意事项:

for 循环中的 i 在循环结束之后,仍然存在与作用域中,为了避免影响作用域中的其他变量,使用函数自执行的方式将其隔离起来 ()() ;

避免使用 for(var i=0; i<demo1Arr.length; i++){} 的方式,这样的数组长度每次都被计算,效率低于上面的方式。也可以将变量声明放在 for 的前面来执行,提高阅读性:

var i = 0, len = demo1Arr.length;

for(; i<len; i++) {};

跳出循环的方式有如下几种:

1、return 函数执行被终止

2、break 循环被终止

3、continue 循环被跳过

for in

for(var item in arr|obj){} 可以用于遍历数组和对象,其中遍历数组时,item 表示索引值, arr 表示当前索引值对应的元素 arr[item];遍历对象时,item 表示 key 值,arr 表示 key 值对应的 value 值 obj[item],具体实现方法如下:

(function() {

for(var i in demoArr) {

if (i == 2) {

  return; // 函数执行被终止
  
  // break;  // 循环被终止
  
  // continue;  // 循环被跳过
  
};

console.log('demoArr['+ i +']:' + demoArr[i]);

}

console.log('-------------');

})();

关于 for in,有以下几点需要注意:

1、在 for 循环与 for in 循环中, i 值都会在循环结束之后保留下来。因此使用函数自执行的方式避免。

2、使用 return,break,continue 跳出循环都与 for 循环一致,不过关于 return 需要注意,在函数体中,return 表示函数执行终止,就算是循环外面的代码,也不再继续往下执行。而 break 仅仅只是终止循环,后面的代码会继续执行。

function res() {

var demoArr = ['Javascript', 'Gulp', 'CSS3', 'Grunt', 'jQuery', 'angular'];

for(var item in demoArr) {

if (item == 2) {

  return;
  
};

console.log(item, demoArr[item]);

}

console.log('desc', 'function res'); //不会执行

}

forEach

demoArr.forEach(function(arg) {})

参数 arg 表示数组每一项的元素,实例如下:

demoArr.forEach(function(e) {

if (e == 'CSS3') {

return;  // 循环被跳过

// break;   // 报错

// continue;// 报错

};

console.log(e);

})

具体有以下需要注意的地方:

1、forEach 无法遍历对象;

2、rEach 无法在 IE 中使用,firefox 和 chrome 则可以实现该方法;

3、forEach 无法使用 break,continue 跳出循环,使用 return 时,效果和在 for 循环中使用 continue 一致。

do/while

函数具体的实现方式如下,不过有一点值得注意的是,当使用 continue 时,如果你将 i++ 放在了后面,那么 i++ 的值将一直不会改变,最后陷入死循环。因此使用 do/while 一定要小心谨慎一点。

不建议使用 do/while 的方式来遍历数组

// 直接使用 while

(function() {

var i = 0,

len = demoArr.length;

while(i < len) {

if (i == 2) {

  // return; // 函数执行被终止
  
  // break;  // 循环被终止
  
  // continue;  // 循环将被跳过,因为后边的代码无法执行,i的值没有改变,因此循环会一直卡在这里,慎用!!
  
};

console.log('demoArr['+ i +']:' + demoArr[i]);

i ++;

}

console.log('------------------------');

})();

// do while

(function() {

var i = 0,

len = demo3Arr.length;

do {

if (i == 2) {

  break; // 循环被终止
  
};

console.log('demo2Arr['+ i +']:' + demo3Arr[i]);

i++;

} while(i<len);

})();

$.each

$.each(demoArr|demoObj, function(e, ele))

可以用来遍历数组和对象,其中 e 表示索引值或者 key 值,ele 表示 value 值

$.each(demoArr, function(e, ele) {

console.log(e, ele);

})

输出为

0 "Javascript"

1 "Gulp"

2 "CSS3"

3 "Grunt"

4 "jQuery"

5 "angular"

这里、需要注意以下几个地方:

1、使用 return 或者 return true 为跳过一次循环,继续执行后面的循环

2、使用 return false 为终止循环的执行,但是并不终止函数执行

3、无法使用 break 与 continue 来跳过循环

4、循环中 this 值输出类似如下

console.log(this);

//String {0: "C", 1: "S", 2: "S", 3: "3", length: 4, [[PrimitiveValue]]: "CSS3"}

console.log(this == ele);

// true

关于上面的 this 值,遍历一下

$.each(this, function(e, ele) {

console.log(e, ele);

})

// 0 c

// 1 s

// 2 s

// 4 3

为什么 length 和 [[PrimitiveValue]]没有遍历出来呢?因为在 javascript 的内部属性中,将对象数据属性中的 Enumerable 设置为了 false;

// 查看 length 的内部属性

console.log(Object.getOwnPropertyDescriptor(this, 'length'));

// Object {value: 4, writable: false, enumerable: false, configurable: false}

.each 中的 (this) 与 this 有所不同,不过遍历结果却是一样。

$(selecter).each

$(selecter).each 是专门用来遍历 DOMList 的:

$('.list li').each(function(i, ele) {

console.log(i, ele);

// console.log(this == ele); // true

$(this).html(i);

if ($(this).attr('data-item') == 'do') {

$(this).html('data-item: do');

};

})

i: 序列值 ele: 只当前被遍历的 DOM 元素

this 当前被遍历的 DOM 元素,不能调用 jQuery 方法

(this) == (ele) 当前被遍历元素的 jquery 对象,可以调用 jquery 的方法进行 dom 操作

使用 for in 遍历 DOMList

因为 domList 并非数组,而是一个对象,只是因为其 key 值为 0,1,2... 而感觉与数组类似,但是直接遍历的结果如下:

var domList = document.getElementsByClassName('its');

for(var item in domList) {

console.log(item, ':' + domList[item]);

}

// 0:

  • // 1:

  • // ...

    // length: 5

    // item: function item() {}

    // namedItem: function namedItem() {}

    因此我们在使用 for in 遍历 domList 时,需要将 domList 转换为数组:

    var res = [].slice.call(domList);

    for(var item in res) {}

    类似这样的对象还有函数的属性 arguments 对象,当然字符串也是可以遍历的,但是因为字符串其他属性的 enumerable 被设置成了 false,因此遍历出来的结果跟数组是一样的,也就不用担心这个问题了。

    以上就是 JavaScript 中,各种遍历的方式及其相关使用,希望对大家在需要对数组或对象进行遍历的时候,有所借鉴吧。

    相关文章:《JavaScript 代码性能优化的 7 条建议》 http://www.maiziedu.com/group/article/6444/

    • JavaScript

      JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

      729 引用 • 1327 回帖

    相关帖子

    欢迎来到这里!

    我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

    注册 关于
    请输入回帖内容 ...

    推荐标签 标签

    • ZeroNet

      ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

      1 引用 • 21 回帖 • 636 关注
    • 京东

      京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

      14 引用 • 102 回帖 • 377 关注
    • 房星科技

      房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

      6 引用 • 141 回帖 • 586 关注
    • uTools

      uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

      6 引用 • 14 回帖 • 1 关注
    • Vditor

      Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

      349 引用 • 1803 回帖
    • Gitea

      Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

      4 引用 • 16 回帖 • 4 关注
    • V2EX

      V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

      17 引用 • 236 回帖 • 325 关注
    • Postman

      Postman 是一款简单好用的 HTTP API 调试工具。

      4 引用 • 3 回帖
    • 锤子科技

      锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

      4 引用 • 31 回帖 • 3 关注
    • HBase

      HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

      17 引用 • 6 回帖 • 71 关注
    • MyBatis

      MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

      170 引用 • 414 回帖 • 385 关注
    • Mac

      Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

      166 引用 • 595 回帖
    • PostgreSQL

      PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

      22 引用 • 22 回帖 • 1 关注
    • B3log

      B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

      1063 引用 • 3453 回帖 • 201 关注
    • Ngui

      Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
      Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

      7 引用 • 9 回帖 • 388 关注
    • Quicker

      Quicker 您的指尖工具箱!操作更少,收获更多!

      31 引用 • 124 回帖 • 4 关注
    • Vim

      Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

      29 引用 • 66 回帖 • 2 关注
    • 自由行
      10 关注
    • 创业

      你比 99% 的人都优秀么?

      84 引用 • 1399 回帖
    • 新人

      让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
      新手上路,请谨慎驾驶!

      52 引用 • 228 回帖 • 1 关注
    • 服务器

      服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

      125 引用 • 588 回帖
    • 宕机

      宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

      13 引用 • 82 回帖 • 53 关注
    • Sandbox

      如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

      406 引用 • 1246 回帖 • 579 关注
    • Hprose

      Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

      9 引用 • 17 回帖 • 612 关注
    • Q&A

      提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

      8044 引用 • 36762 回帖 • 162 关注
    • 面试

      面试造航母,上班拧螺丝。多面试,少加班。

      325 引用 • 1395 回帖
    • GAE

      Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

      14 引用 • 42 回帖 • 761 关注