第十周web作业1

for each in:

使用一个变量迭代一个对象的所有属性值,对于每一个属性值,有一个指定的语句块被执行.

语法:

1 for each (variable in object) {
2   statement
3 }

参数:

variable:用来遍历属性值的变量,前面的var关键字是可选的.该变量是函数的局部变量而不是语句块的局部变量.
object:该对象的属性值会被遍历.
statement:遍历属性值时执行的语句. 如果想要执行多条语句, 请用({ ... }) 将多条语句括住.

一些对象的内置属性是无法被遍历到的,包括所有的内置方法,例如String对象的indexOf方法.不过,大部分的用户自定义属性都是可遍历的.

警告:永远不要使用for each...in语句遍历数组,仅用来遍历常规对象。

例子:

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:

以任意顺序遍历一个对象的可枚举属性。对于每个不同的属性,语句都会被执行。

语法:

1 for (variable in object) {...}

参数:

variable:在每次迭代时,将不同的属性名分配给变量。

object:被迭代其枚举属性的对象。
for..in 不应该被用来迭代一个下标顺序很重要的 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

猜你喜欢

转载自www.cnblogs.com/black-tea/p/9943954.html