JS中 for.. in.和 for of 的区别

普通的for循环的基本格式为:

for(int i ; i < 10 ; i++){
    ...
}

在 js 中则存在另外的 for 循环格式.  for ..in   和  for...of ,接下来将介绍一下这两个的区别

for in是ES5标准,遍历key. 
for of是ES6标准,遍历value.

 

for ... in  : 遍历的是对象的属性,类似于键值对里的键key,当它遍历array的时候遍历的是array的索引

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

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
 alert(x);//'A', 'B', 'C'
}
for (var x of s) { // 遍历Set
 alert(x);//'A', 'B', 'C'
}
for (var x of m) { // 遍历Map
 alert(x[0] + '=' + x[1]);//1='x',2='y',3='z'
}

用两种循环来解析 json 数据时:

//for in 循环
for(var d in data){
	html+="<tr><td>"+ data[d].id + " </td> <td>"+ data[d].name +" </td> <td>" 
             + data[d].password+"</td> </tr>";
}

//for of 循环
for(var d of data){
	html+="<tr><td>"+ d['id'] + " </td> <td>"+ d['name'] +" </td> <td>" + d['password']
               +" </td> </tr>"
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值