第十周web做业1

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:被迭代其枚举属性的对象。
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
相关文章
相关标签/搜索