for循环的一个变体是for ... in循环,它可以把一个对象的所有属性依次循环出来:

var o = {
name: 'Jack',
age: 20,
city: 'Beijing'
};
for (var key in o) {
console.log(key); // 'name', 'age', 'city'
}

  要过滤掉对象继承的属性,用hasOwnProperty()来实现:

var o = {
name: 'Jack',
age: 20,
city: 'Beijing'
};
for (var key in o) {
if (o.hasOwnProperty(key)) {
console.log(key); // 'name', 'age', 'city'
}
}

  由于Array也是对象,而它的每个元素的索引被视为对象的属性,因此,for ... in循环可以直接循环出Array的索引:

var a = ['A', 'B', 'C'];
for (var i in a) {
console.log(i); // '0', '1', '2'
console.log(a[i]); // 'A', 'B', 'C'
}

  请注意,for ... inArray的循环得到的是String而不是Number

for ... of循环是ES6引入的新的语法:用for ... of循环遍历集合,用法如下:

var a = ['A', 'B', 'C'];
var s = new Set(['A', 'B', 'C']);
var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
for (var x of a) { // 遍历Array
console.log(x);
}
for (var x of s) { // 遍历Set
console.log(x);
}
for (var x of m) { // 遍历Map
console.log(x[0] + '=' + x[1]);
}

  

你可能会有疑问,for ... of循环和for ... in循环有何区别?

for ... in循环由于历史遗留问题,它遍历的实际上是对象的属性名称。一个Array数组实际上也是一个对象,它的每个元素的索引被视为一个属性。

当我们手动给Array对象添加了额外的属性后,for ... in循环将带来意想不到的意外效果:

var a = ['A', 'B', 'C'];
a.name = 'Hello';
for (var x in a) {
console.log(x); // '0', '1', '2', 'name'
}

  

for ... in循环将把name包括在内,但Arraylength属性却不包括在内。

for ... of循环则完全修复了这些问题,它只循环集合本身的元素:

var a = ['A', 'B', 'C'];
a.name = 'Hello';
for (var x of a) {
console.log(x); // 'A', 'B', 'C'
}

  然而,更好的方式是直接使用iterable内置的forEach方法,它接收一个函数,每次迭代就自动回调该函数。以Array为例:

'use strict';
var a = ['A', 'B', 'C'];
a.forEach(function (element, index, array) {
// element: 指向当前元素的值
// index: 指向当前索引
// array: 指向Array对象本身
console.log(element + ', index = ' + index);
});

  

如果对某些参数不感兴趣,由于JavaScript的函数调用不要求参数必须一致,因此可以忽略它们。例如,只需要获得Arrayelement

var a = ['A', 'B', 'C'];
a.forEach(function (element) {
console.log(element);
});

  

最新文章

  1. 关于Oracle表连接
  2. HTML 事件属性(下)
  3. Silverlight读取Zip文件中的图片与视频
  4. [转贴]超级懒汉编写的基于.NET的微信SDK
  5. OpenGL三维镂垫
  6. 最全SpringMVC具体演示样例实战教程
  7. HOW TO: How to import UUID function into Postgre 9.3
  8. HDU 2568[前进]模拟
  9. maven项目无法查看方法
  10. 【Netty】Netty传输
  11. 深入js隐式类型转换
  12. js 零散知识总结
  13. WPF DEV dxc:ChartControl 柱状图
  14. 【资料收集】OpenCV入门指南 系列文章
  15. C++中类的多继承
  16. [转]MySQL DBA面试全揭秘
  17. python3.4学习笔记(一) 基本语法 python3不向下兼容,有些语法跟python2.x不一样
  18. 单链表(c语言实现)贼详细
  19. C#对Windows服务组的启动与停止
  20. 视觉SLAM实战(一):RGB-D SLAM V2

热门文章

  1. Sobel边缘检测
  2. jQuery cookie 实现记住用户名和密码功能
  3. SpringMVC 文件上传及下载
  4. string(未完待续)
  5. Python习题-一个函数实现读写功能
  6. PHP 常量、PHP 变量全解析(超全局变量、变量的8种数据类型等)
  7. Servlet简单增删改查
  8. BEC listen and translation exercise 36
  9. codeforces 622B B. The Time
  10. inux命令学习笔记(5):rm 命令