JavaScript 中有哪些遍历方式?

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

不管是移动移动端开发还是 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}

(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 方法

(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 引用 • 1278 回帖

    相关帖子

    欢迎来到这里!

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

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

    推荐标签 标签

    • 资讯

      资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

      56 引用 • 85 回帖 • 1 关注
    • Angular

      AngularAngularJS 的新版本。

      26 引用 • 66 回帖 • 544 关注
    • 又拍云

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

      20 引用 • 37 回帖 • 567 关注
    • 旅游

      希望你我能在旅途中找到人生的下一站。

      93 引用 • 901 回帖
    • RabbitMQ

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

      49 引用 • 60 回帖 • 353 关注
    • 创造

      你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

      182 引用 • 1010 回帖 • 2 关注
    • 微服务

      微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

      96 引用 • 155 回帖
    • Facebook

      Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

      4 引用 • 15 回帖 • 441 关注
    • 外包

      有空闲时间是接外包好呢还是学习好呢?

      26 引用 • 233 回帖 • 1 关注
    • 知乎

      知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

      10 引用 • 66 回帖
    • Openfire

      Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

      6 引用 • 7 回帖 • 98 关注
    • 音乐

      你听到信仰的声音了么?

      61 引用 • 512 回帖 • 2 关注
    • CSDN

      CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

      14 引用 • 155 回帖
    • 前端

      前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

      245 引用 • 1338 回帖 • 2 关注
    • Flume

      Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

      9 引用 • 6 回帖 • 653 关注
    • 印象笔记
      3 引用 • 16 回帖 • 1 关注
    • Node.js

      Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

      139 引用 • 269 回帖 • 1 关注
    • Postman

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

      4 引用 • 3 回帖 • 4 关注
    • Eclipse

      Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

      76 引用 • 258 回帖 • 635 关注
    • ActiveMQ

      ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

      19 引用 • 13 回帖 • 683 关注
    • GitHub

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

      210 引用 • 2040 回帖
    • HBase

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

      17 引用 • 6 回帖 • 69 关注
    • HHKB

      HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

      5 引用 • 74 回帖 • 493 关注
    • Vim

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

      29 引用 • 66 回帖 • 1 关注
    • Redis

      Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

      286 引用 • 248 回帖 • 14 关注
    • B3log

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

      1063 引用 • 3455 回帖 • 168 关注
    • 自由行