JavaScript 中有哪些遍历方式?

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

不管是移动移动端开发还是 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 网页增加动态功能。

      710 引用 • 1173 回帖 • 193 关注

    相关帖子

    欢迎来到这里!

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

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

    推荐标签 标签

    • 禅道

      禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

      5 引用 • 15 回帖 • 222 关注
    • RabbitMQ

      RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

      49 引用 • 60 回帖 • 394 关注
    • Dubbo

      Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

      60 引用 • 82 回帖 • 591 关注
    • 运维

      互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

      148 引用 • 257 回帖
    • 星云链

      星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

      3 引用 • 16 回帖 • 2 关注
    • abitmean

      有点意思就行了

      14 关注
    • AngularJS

      AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

      12 引用 • 50 回帖 • 409 关注
    • 爬虫

      网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

      106 引用 • 275 回帖
    • Wide

      Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

      欢迎访问我们运维的实例: https://wide.b3log.org

      30 引用 • 218 回帖 • 594 关注
    • Docker

      Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

      475 引用 • 899 回帖
    • 深度学习

      深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

      40 引用 • 40 回帖
    • WebSocket

      WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

      48 引用 • 206 回帖 • 407 关注
    • CloudFoundry

      Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

      5 引用 • 18 回帖 • 150 关注
    • 小薇

      小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

      由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

      34 引用 • 467 回帖 • 688 关注
    • Laravel

      Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

      19 引用 • 23 回帖 • 675 关注
    • Q&A

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

      6364 引用 • 28621 回帖 • 264 关注
    • 又拍云

      又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

      21 引用 • 37 回帖 • 505 关注
    • ngrok

      ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

      7 引用 • 63 回帖 • 598 关注
    • Quicker

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

      16 引用 • 68 回帖
    • GitLab

      GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

      46 引用 • 72 回帖
    • jsoup

      jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

      6 引用 • 1 回帖 • 457 关注
    • Swagger

      Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

      26 引用 • 35 回帖 • 7 关注
    • 程序员

      程序员是从事程序开发、程序维护的专业人员。

      529 引用 • 3527 回帖
    • Pipe

      Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

      这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

      131 引用 • 1114 回帖 • 152 关注
    • GitBook

      GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

      3 引用 • 8 回帖
    • GitHub

      GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

      207 引用 • 2031 回帖
    • 反馈

      Communication channel for makers and users.

      123 引用 • 906 回帖 • 176 关注