javascript总for of和for in的区别
2个回答
展开全部
简单说,for in是遍历键名,for of是遍历键值。
例如:
let arr = ["q","c"];
for (a in arr) {
console.log(a);//1,2
}
for (a of arr) {
console.log(a);//q,c
}
由于for of的这个特性,他还可以实现对iterator对象的遍历,而for in就是简单的遍历了。
兼容方面来说
for in是ES5标准,for of是ES6标准;
for of兼容性还不够,移动端安卓(6.0以下)微信浏览器貌似不支持,苹果的可以;web端IE支持也不够,chrome可以。
展开全部
<!--
for...in用来迭代对象的属性名,然后可以以关联数组的形式访问对象的对应属性名的属性值(可能浏览器不支持)
for...of用来直接迭代对象的属性值(可能浏览器不支持)
下面这个例子显示了document对象的所有属性名-属性值对。
-->
<html>
<body>
<script type="text/javascript">
//<!--
for(var p in document)
{
document.write("document."+p+"="+document[p]+"<br />");
}
document.write("<br />");
//-->
</script>
<script type="text/javascript">
//<!--
for(var pv of document)
{
document.write(pv+"<br />");
}
//-->
</script>
</body>
</html>
for...in用来迭代对象的属性名,然后可以以关联数组的形式访问对象的对应属性名的属性值(可能浏览器不支持)
for...of用来直接迭代对象的属性值(可能浏览器不支持)
下面这个例子显示了document对象的所有属性名-属性值对。
-->
<html>
<body>
<script type="text/javascript">
//<!--
for(var p in document)
{
document.write("document."+p+"="+document[p]+"<br />");
}
document.write("<br />");
//-->
</script>
<script type="text/javascript">
//<!--
for(var pv of document)
{
document.write(pv+"<br />");
}
//-->
</script>
</body>
</html>
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询