首页 >web前端 >js教程 >JavaScript 的 `for...in` 和 `for...of` 循环有什么区别?

JavaScript 的 `for...in` 和 `for...of` 循环有什么区别?

Linda Hamilton
Linda Hamilton原创
2024-12-19 20:48:15586浏览

What's the Difference Between JavaScript's `for...in` and `for...of` Loops?

理解 (for... in) 和 (for... of) 语句之间的区别

简介

Javascript 提供了两个循环语句,(for...in) 和 (for...of),它们在迭代对象和数据结构。

for... of:迭代属性值

ES6 中引入的 (for... of) 语句提供迭代对象属性值的便捷​​方法。与循环属性名称的 (for... in) 不同,(for... of) 特别关注属性值。

这种区别在提供的示例中变得清晰:

var arr = [3, 5, 7];
arr.foo = "hello";

for (var i in arr) {
  console.log(i); // logs "0", "1", "2", "foo"
}

for (var i of arr) {
  console.log(i); // logs "3", "5", "7"
}

虽然 (for... in) 记录数字索引(“0”、“1”、“2”)和自定义属性“foo”(ES6 迭代器通常不包括键),但 (for... of) 仅记录记录数字属性值(“3”、“5”、“7”)。这样做的原因是 (for... of) 使用了一个专注于属性值的特定于对象的迭代器。

总而言之,(for... of) 提供了一种简洁且以值为中心的方法迭代对象中的属性。它会跳过非索引属性,例如示例中的“foo”属性,并直接提供属性值作为循环迭代。

以上是JavaScript 的 `for...in` 和 `for...of` 循环有什么区别?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn