JavaScript各种遍历方式详解

为了方便例子讲解,现有数组和json对象如下

1 var demoArr = [‘Javascript‘, ‘Gulp‘, ‘CSS3‘, ‘Grunt‘, ‘jQuery‘, ‘angular‘];
2 var demoObj = {
3     aaa: ‘Javascript‘,
4     bbb: ‘Gulp‘,
5     ccc: ‘CSS3‘,
6     ddd: ‘Grunt‘,
7     eee: ‘jQuery‘,
8     fff: ‘angular‘
9 };

for

可以直接看示例,用得太多了,很简单

 1 (function() {
 2     for(var i=0, len=demoArr.length; i<len; i++) {
 3         if (i == 2) {
 4             // return;   // 函数执行被终止
 5             // break;    // 循环被终止
 6             continue; // 循环被跳过
 7         };
 8         console.log(‘demo1Arr[‘+ i +‘]:‘ + demo1Arr[i]);
 9     }
10 })();

关于for循环,有一下几点需要注意

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

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

for in

for(var item in arr|obj){} 可以用于遍历数组和对象

遍历数组时,item表示索引值, arr表示当前索引值对应的元素 arr[item]

遍历对象时,item表示key值,arr表示key值对应的value值 obj[item]

 1 (function() {
 2     for(var i in demoArr) {
 3         if (i == 2) {
 4             return; // 函数执行被终止
 5             // break;  // 循环被终止
 6             // continue;  // 循环被跳过
 7         };
 8         console.log(‘demoArr[‘+ i +‘]:‘ + demoArr[i]);
 9     }
10     console.log(‘-------------‘);
11 })();

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

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

使用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表示数组每一项的元素,实例如下

1 demoArr.forEach(function(val, index) {
2     if (e == ‘CSS3‘) {
3         return;  // 循环被跳过
4         // break;   // 报错
5         // continue;// 报错
6     };
7     console.log(val, index);
8 })

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

回调函数中有2个参数,分别表示值和索引,这一点与jQuery中的$.each相反

forEach无法遍历对象

forEach无法在IE中使用,firefox和chrome实现了该方法

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

最重要的一点,可以添加第二参数,为一个数组,而且回调函数中的this会指向这个数组。而如果没有第二参数,则this会指向window。

1 var newArr = [];
2 demoArr.forEach(function(val, index) {
3     this.push(val); // 这里的this指向newArr
4 }, newArr)

虽然在原生中forEach循环的局限性很多,但是了解他的必要性在于,很多第三方库会扩展他的方法,使其能够应用在很多地方,比如angular的工具方法中,也有forEach方法,其使用与原生的基本没有差别,只是没有了局限性,可以在IE下使用,也可以遍历对象

do/while

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

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

 1 // 直接使用while
 2 (function() {
 3     var i = 0,
 4         len = demoArr.length;
 5     while(i < len) {
 6         if (i == 2) {
 7             // return; // 函数执行被终止
 8             // break;  // 循环被终止
 9             // continue;  // 循环将被跳过,因为后边的代码无法执行,i的值没有改变,因此循环会一直卡在这里,慎用!!
10         };
11         console.log(‘demoArr[‘+ i +‘]:‘ + demoArr[i]);
12         i ++;
13     }
14     console.log(‘------------------------‘);
15 })();
16
17 // do while
18 (function() {
19     var i = 0,
20         len = demo3Arr.length;
21     do {
22         if (i == 2) {
23             break; // 循环被终止
24         };
25         console.log(‘demo2Arr[‘+ i +‘]:‘ + demo3Arr[i]);
26         i++;
27     } while(i<len);
28 })();

$.each

$.each(demoArr|demoObj, function(e, ele))
可以用来遍历数组和对象,其中e表示索引值或者key值,ele表示value值

1 $.each(demoArr, function(e, ele) {
2     console.log(e, ele);
3 })

这里有很多需要注意的地方

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

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

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

循环中this值输出类似如下

1 console.log(this);
2 //String {0: "C", 1: "S", 2: "S", 3: "3", length: 4, [[PrimitiveValue]]: "CSS3"}
3
4 console.log(this == ele);
5 // true

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

$.each(this, function(e, ele) {
    console.log(e, ele);
})

// 0 c
// 1 s
// 2 s
// 4 3

$(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,因此遍历出来的结果跟数组是一样的,也就不用担心这个问题了.

小补充

+function(ROOT, Struct, undefined) {
    ...
}(window, function() {
    function Person() {}
})

()(),!function() {}(), +function() {}() 三种函数自执行的方式

时间: 2024-07-29 07:56:13

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 可以直接看示例,用得太多了,很简单 (function() { for(var

JavaScript中继承方式详解

继承一直是面向对象语言中的一个最为人津津乐道的概念,在JavaScript中,继承也是难点之一,下面我尽量用通俗的语言来介绍一下实现继承的几种方法. 原型链 ECMAScript 中描述了原型链的概念,并将原型链作为实现继承的主要方法.其基本思想是利用原型让一个引用类型继承另一个引用类型的属性和方法.这个基本思想说的一点也不基本,那么先说一个在之前博文中提到的概念,原型与实例的关系.我们知道:每一个实例里包含了原型对象中的方法和属性.这是因为任何一个对象都有一个内部属性[[prototype]]

javascript AJAX与Comet详解

          博客专家福利      [限时活动]建专辑得大奖       专访荣浩:流程的永恒之道      当青春遇上互联网,能否点燃你的创业梦      推荐有礼--找出您心中的技术大牛 javascript AJAX与Comet详解 分类: javascript2012-12-24 17:39 367人阅读 评论(0) 收藏 举报 XMLHttpRequest对象 在IE5中,XHR对象是通过MSXML库中的ActiveX对象实现的.在IE中可能会遇到三种不同版本的XHR对象,即M

【JavaScript中的this详解】

前言 this用法说难不难,有时候函数调用时,往往会搞不清楚this指向谁?那么,关于this的用法,你知道多少呢? 下面我来给大家整理一下关于this的详细分析,希望对大家有所帮助! this指向的规律 this指向的规律往往与函数调用的方式息息相关:this指向的情况,取决于函数调用的方法有哪些. 我们来看一下姜浩五大定律: 姜浩五大定律: ①通过函数名()直接调用:this指向window: ②通过对象.函数名()调用的:this指向这个对象: ③函数作为数组的一个元素,通过数组下标调用的

Linux用户态程序计时方式详解

前言 良好的计时器可帮助程序开发人员确定程序的性能瓶颈,或对不同算法进行性能比较.但要精确测量程序的运行时间并不容易,因为进程切换.中断.共享的多用户.网络流量.高速缓存访问及转移预测等因素都会对程序计时产生影响. 本文将不考虑这些影响因素(相关资料可参考<深入理解计算机系统>一书),而仅仅关注Linux系统中用户态程序执行时间的计算方式.除本文所述计时方式外,还可借助外部工具统计耗时,如<Linux调试分析诊断利器——strace>一文中介绍的strace. 本文示例代码的运行环

深入理解Oracle表(3):三大表连接方式详解之Nested loop join和 Sort merge join

深入理解Oracle表(3):三大表连接方式详解之Nested loop join和 Sort merge join 分类: Oracle 基础管理 Oracle SQL 开发2013-01-28 00:33 2536人阅读 评论(1) 收藏 举报 关系数据库技术的精髓就是通过关系表进行规范化的数据存储       并通过各种表连接技术和各种类型的索引技术来进行信息的检索和处理       这里Think愿意和大家一起来学习分享Oracle的三大表连接技术              在早期版本,

Javascript 异步加载详解(转)

本文总结一下浏览器在 javascript 的加载方式. 关键词:异步加载(async loading),延迟加载(lazy loading),延迟执行(lazy execution),async 属性, defer 属性 一.同步加载与异步加载的形式 1. 同步加载 我们平时最常使用的就是这种同步加载形式: <script src="http://yourdomain.com/script.js"></script> 同步模式,又称阻塞模式,会阻止浏览器的后续

物理真实网络连接和虚拟机联网的方式详解

物理真实网络连接和虚拟机联网的方式详解 一.物理真实网络连接图详解 二.查找VMware指定虚拟IP: 1. 2. 3. 三.注意:Linux虚拟网络连接有以下几种: 1.NAT方式(这种方式CentOS可以上外网) 2.桥接方式(bridging)(这种方式CentOS可以上外网) 3.hostonly方式(注意:这种方式CentOS不可以上外网) 四.虚拟机的IP在window上ping下,看能不能拼的通,如果拼的通,说明linux上可以上外网 1.查看linux下ip 2.在window上

android adb 的各种使用方式详解

这篇文章主要介绍在windows 程序中使用adb 的方法,不介绍adb 的命令. 1) 启动adb 进程,从管道获取输出. 这种方式的弊端有多少,我也不知道,反正就是各种问题吧.但是目前我问过很多朋友,他们都是这么做的,因为这种方法最简单.弊端我列举一下 1) 每次执行一个adb 命令都要启动一个adb 进程,速度太慢,好像就是很不爽 2)  偶尔发现进程管理器中有N 多个adb 进程,然后就卡了. 3)  从管道获取输出,在很多情况下会发现adb 卡死了,进程退不出来. 4)  曾经发现 a