JavaScript 中有哪些遍历方式?

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

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

    相关帖子

    欢迎来到这里!

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

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

    推荐标签 标签

    • TensorFlow

      TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

      20 引用 • 19 回帖
    • wolai

      我来 wolai:不仅仅是未来的云端笔记!

      2 引用 • 14 回帖
    • Ubuntu

      Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的 Linux 操作系统,其名称来自非洲南部祖鲁语或豪萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观,类似华人社会的“仁爱”思想。Ubuntu 的目标在于为一般用户提供一个最新的、同时又相当稳定的主要由自由软件构建而成的操作系统。

      125 引用 • 169 回帖 • 1 关注
    • InfluxDB

      InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

      2 引用 • 72 关注
    • Ruby

      Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

      7 引用 • 31 回帖 • 210 关注
    • Openfire

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

      6 引用 • 7 回帖 • 94 关注
    • JavaScript

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

      729 引用 • 1327 回帖
    • Vim

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

      29 引用 • 66 回帖
    • BAE

      百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

      19 引用 • 75 回帖 • 641 关注
    • 安装

      你若安好,便是晴天。

      132 引用 • 1184 回帖
    • 知乎

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

      10 引用 • 66 回帖
    • 钉钉

      钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

      15 引用 • 67 回帖 • 340 关注
    • 安全

      安全永远都不是一个小问题。

      199 引用 • 816 回帖 • 1 关注
    • 面试

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

      325 引用 • 1395 回帖
    • OkHttp

      OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

      16 引用 • 6 回帖 • 62 关注
    • Dubbo

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

      60 引用 • 82 回帖 • 595 关注
    • uTools

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

      6 引用 • 14 回帖 • 2 关注
    • Bootstrap

      Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

      18 引用 • 33 回帖 • 660 关注
    • TextBundle

      TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

      1 引用 • 2 回帖 • 48 关注
    • ZooKeeper

      ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

      59 引用 • 29 回帖 • 4 关注
    • 负能量

      上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

      88 引用 • 1235 回帖 • 411 关注
    • Netty

      Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

      49 引用 • 33 回帖 • 21 关注
    • 宕机

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

      13 引用 • 82 回帖 • 52 关注
    • Windows

      Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

      222 引用 • 473 回帖
    • 百度

      百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

      63 引用 • 785 回帖 • 177 关注
    • 数据库

      据说 99% 的性能瓶颈都在数据库。

      342 引用 • 708 回帖
    • 酷鸟浏览器

      安全 · 稳定 · 快速
      为跨境从业人员提供专业的跨境浏览器

      3 引用 • 59 回帖 • 26 关注