for each in:数组
使用一个变量迭代一个对象的全部属性值,对于每个属性值,有一个指定的语句块被执行.数据结构
语法:函数
1 for each (variable in object) { 2 statement 3 }
参数:spa
variable:
用来遍历属性值的变量,前面的var
关键字是可选的.该变量是函数的局部变量而不是语句块的局部变量.
object:
该对象的属性值会被遍历.
statement:
遍历属性值时执行的语句. 若是想要执行多条语句, 请用({ ... }
) 将多条语句括住.
一些对象的内置属性是没法被遍历到的,包括全部的内置方法,例如String对象的indexOf
方法.不过,大部分的用户自定义属性都是可遍历的.code
警告:永远不要使用for each...in语句遍历数组,仅用来遍历常规对象。对象
例子:blog
1 var sum = 0; 2 var obj = {prop1: 5, prop2: 13, prop3: 8}; 3 4 for each (var item in obj) { 5 sum += item; 6 } 7 8 print(sum); // 输出"26",也就是5+13+8的值
for in:继承
以任意顺序遍历一个对象的可枚举属性。对于每一个不一样的属性,语句都会被执行。索引
语法:ip
1 for (variable in object) {...}
参数:
variable:
在每次迭代时,将不一样的属性名分配给变量。
object:
被迭代其枚举属性的对象。
Array
.for...in 并不可以保证返回的是按必定顺序的索引,可是它会返回全部可枚举属性,包括非整数名称的和继承的。
1 var obj = {a:1, b:2, c:3}; 2 3 for (var prop in obj) { 4 console.log("obj." + prop + " = " + obj[prop]); 5 } 6 7 // Output: 8 // "obj.a = 1" 9 // "obj.b = 2" 10 // "obj.c = 3"
for of:
for...of 语句建立一个循环来迭代可迭代的对象。在 ES6 中引入的 for...of
循环,以替代 for...in
和 forEach()
,并支持新的迭代协议。for...of
容许你遍历 Arrays(数组), Strings(字符串), Maps(映射), Sets(集合)等可迭代的数据结构等。
语法:
1 for (variable of iterable) { 2 statement 3 }
参数:
variable:每一个迭代的属性值被分配给该变量。
iterable:一个具备可枚举属性而且能够迭代的对象。
例子:
1 // array-example.js 2 const iterable = ['mini', 'mani', 'mo']; 3 4 for (const value of iterable) { 5 console.log(value); 6 } 7 8 // Output: 9 // mini 10 // mani 11 // mo