如何在JavaScript中使用for循环

如何,javascript,使用,for,循环 · 浏览次数 : 502

小编点评

**JavaScript for...in循环** `for...in`循环是JavaScript中用于遍历对象的强大方法。它允许我们遍历对象的键或属性,并访问其值。 **语法** ```javascript for (key in object) { // 循环内的代码 } ``` **用途** * **遍历对象** * **访问对象的键或属性** * **进行调试** **优点** * 支持遍历对象的键或属性 * 允许访问对象的多个值 * 使用简洁的语法 **缺点** * 遍历顺序随机,可能与预期不同 * 无法访问对象的子对象 * 在修改对象属性时,循环顺序可能不保持 **示例** ```javascript const obj = { name: "John", age: 30, city: "New York" }; // 使用 for...in 遍历对象 for (let key in obj) { console.log(key, obj[key]); } // 输出结果 // name: John age: 30 city: New York ``` **替代方案** * `forEach` 方法:使用 `forEach` 方法可以遍历数组并访问其元素。 * `Object.keys()` 方法:使用 `Object.keys()` 方法可以遍历对象并获取其键名。 * `Object.values()` 方法:使用 `Object.values()` 方法可以遍历对象并获取其值。 **注意** * `for...in` 循环只遍历对象属性,不会遍历子对象。 * 在使用 `for...in` 循环时,要小心修改对象属性的顺序,以确保循环顺序正确。

正文

前言

循环允许我们通过循环数组或对象中的项并做一些事情,比如说打印它们,修改它们,或执行其他类型的任务或动作。JavaScript有各种各样的循环,for循环允许我们对一个集合(如数组)进行迭代。

在这篇文章中,我们将了解JavaScript提供的for循环。我们将看看for...in循环语句是如何在JavaScript中使用的,它的语法,它如何工作的例子,何时使用它或避免它,以及我们可以使用哪些其他类型的循环来代替。

为什么使用for循环

在JavaScript中,就像在其他编程语言中一样,我们使用循环来读取或访问集合中的项。这个集合可以是一个数组或一个对象。每当循环语句在一个集合中的项中循环时,我们称之为一个迭代

有两种方式可以访问集合中的项。第一种方式是通过它在集合中的键,也就是数组中的索引或对象中的属性。第二种方式是通过集合项本身,而不需要键。

for…in循环的定义

JavaScript的for循环会或迭代集合中的键。使用这些键,你就可以访问它在集合中代表的项。

集合的项可以是数组,也可以是对象,甚至可以是字符串。

for…in循环的语法

for循环具有以下语法或结构:

for (let key in value) {
  //do something here
}

在上述代码块中,value是我们迭代的项的集合。它可以是对象、数组、字符串等等。key会是value每一项的键,在每次迭代中都会改变到列表中的下一个键。

注意,这里我们使用letconst来声明key

for-in-loop-diagram.png

在对象中使用for…in循环

在JavaScript中使用for...in循环迭代对象时,其迭代的键或者属性是对象自己的属性(在上面的示例中,由key变量表示)。

由于对象可能通过原型链继承数据项,其中包括对象的默认方法和属性,以及我们可能定义的对象原型,因此我们应该使用hasOwnProperty

在下面的例子中,我们通过变量obj进行循环,并打印每一个属性和值:

const obj = {
  "a": "JavaScript",
  1: "PHP",
  "b": "Python",
  2: "Java"
};

for (let key in obj) {
  console.log(key + ": " + obj[key] )
}

// Output:
// "1: PHP"
// "2: Java"
// "a: JavaScript"
// "b: Python"

请注意,键的迭代顺序是升序的(也就是说,从数字开始,按数字的顺序,然后是字母,按字母的顺序)。然而,这个输出的顺序与初始化对象时创建的项的索引顺序不同。

在数组中使用for…in循环

在JavaScript中使用for...in循环来迭代数组时,在这种情况下,key将是元素的索引。然而,索引可以按随机顺序迭代。

因此,如果我们上面展示的for...in循环语法结构中的value变量是一个包含五项的数组,那么key就不能保证是0到4。一些索引可能会在其他索引之前。关于何时可能发生这种情况的细节将在本文后面解释。

在下面的例子中,我们对arr变量进行循环:

const arr = ["JavaScript", "PHP", "Python", "Java"];

for (let key in arr) {
  console.log(key + ": " + arr[key])
}

// Output:
// "0: JavaScript"
// "1: PHP"
// "2: Python"
// "3: Java"

在循环中,我们呈现每个数组元素的索引和值。

在字符串中使用for…in循环

你可以在JavaScript中使用for…in循环来循环字符串。然而,不推荐这么做,因为你将在字符串的索引上循环,而不是字符串本身。

在下面的例子中,我们对str变量进行循环:

const str = "Hello!";

for (let key in str) {
  console.log(key + ": " + str.charAt(key));
}

//Output
// "0: H"
// "1: e"
// "2: l"
// "3: l"
// "4: o"
// "5: !"

在这个循环中,我们要呈现每个字符的键或索引,以及该索引的字符。

让我们看看JavaScript for…in循环最适合的情况。

使用for…in循环迭代对象

因为for...in循环只迭代对象的可枚举属性,也就是对象自有属性,而不是像toString这样属于对象原型的属性。所以使用for...in循环来迭代对象是很好的。for...in循环提供了一个简单的方法来迭代一个对象的属性并最终得到它的值。

使用for…in循环调试

JavaScript for...in循环的另一个很好的用例是调试。比如,你可能想向控制台或HTML元素打印一个对象的属性和它的值。在这种情况下,for...in循环是一个不错的选择。

当使用for…in循环调试对象以及对象的值时,你应该始终记住,迭代是没有顺序的。也就是说,迭代的顺序是随机的。所以,访问属性的顺序可能与预期不同。

不使用for…in循环的情形

现在让我们来看看for...in循环不是最佳选择的情况。

数组的有序迭代

由于使用for...in循环时不能保证迭代中的索引顺序,如果有必要保持顺序,建议不要迭代数组。

如果你想支持像IE这样的浏览器,这一点尤其重要,因为IE是按照数组项创建的顺序而不是按照索引的顺序进行迭代的。这与当前现代浏览器的工作方式不同,后者是根据索引的升序来迭代数组的。

举例来说,如果你有一个包含四项的数组,你在索引3的位置插入了一项,在现代浏览器中,for...in循环仍然会按照从0到4的顺序遍历数组。 在IE中,当使用for...in循环时,它将遍历一开始就在数组中的四个项目,然后再遍历在索引3的位置添加的那一项。

迭代时进行更改

对属性的任何添加、删除或修改都不能保证有序的迭代。应该避免在for...in循环中对属性进行更改。这主要是由于它的无序性。

因此,如果你在迭代到达某一项之前删除它,那么这项在整个循环中根本就不会被访问。

同样地,如果你对一个属性进行修改,并不能保证这项不会被再次访问。因此,如果一个属性被改变,它可能会在循环中被访问两次而不是一次。

除此之外,如果一个属性在迭代过程中被添加,那么它在迭代过程中可能会被访问,也可能根本不会被访问。

由于这些情况,最好避免在for...in循环中对一个对象进行任何修改、删除或添加。

下面是一个在for...in循环中添加元素的例子。我们可以看到第一个循环的结果,然后是在第一个循环中进行添加后的第二个循环的结果。

<h2>Before</h2>
<div id="loopResultsBefore"></div>
<h2>After</h2>
<div id="loopResultsAfter"></div>
const beforeDiv = document.getElementById('loopResultsBefore');

const afterDiv = document.getElementById('loopResultsAfter');

const obj = {
  "a": "JavaScript",
  1: "PHP",
  "b": "Python",
  2: "Java"
};

for (let key in obj) {
  beforeDiv.innerHTML += key + ": " + obj[key] + "<br />";
  if (!isNaN(key)) {
    obj[key - 1] = obj[key];
  }
}

for (let key in obj) {
  afterDiv.innerHTML += key + ": " + obj[key] + "<br />";
}

// Before
// 1: PHP
// 2: Java
// a: JavaScript
// b: Python
// After
// 0: PHP
// 1: Java
// 2: Java
// a: JavaScript
// b: Python

正如你在上面的例子中看到的,被添加的元素并没有被迭代。

for循环的替代方案

forEach在JavaScript中是数组原型的一个方法,它允许我们在回调函数中遍历数组的元素和它们的索引。

回调函数是你传递给另一个方法或函数的函数,作为该方法或函数执行的一部分而被执行。当涉及到JavaScript中的forEach时,它意味着回调函数将在每个迭代中执行,接收迭代中的当前项作为参数。

举例来说,下面的语句使用forEach迭代arr变量,并在console中打印value

arr.forEach((value) => console.log(value));

你也可以访问数组的索引:

arr.forEach((value, index) => console.log(value, index));

JavaScript forEach循环也可以使用Object.keys()来迭代对象,把你想迭代的对象传给它,它返回对象的自有属性数组:

Object.keys(obj).forEach((key) => console.log(obj[key]));

另外,如果你不需要使用Object.values()来访问属性,你可以用forEach来直接循环属性的值:

Object.values(obj).forEach((value) => console.log(value));

注意,Object.values()返回项的顺序与for...in相同。

总结

通过使用JavaScript for...in循环,我们可以循环对象的键或属性。在迭代对象属性或进行调试时,它可能很有用,但在迭代数组或对对象进行修改时,应该避免使用for...in循环。

以上就是文章的所有内容,如果对你有所帮助,欢迎收藏点赞转发~

与如何在JavaScript中使用for循环相似的内容:

如何在JavaScript中使用for循环

前言 循环允许我们通过循环数组或对象中的项并做一些事情,比如说打印它们,修改它们,或执行其他类型的任务或动作。JavaScript有各种各样的循环,for循环允许我们对一个集合(如数组)进行迭代。 在这篇文章中,我们将了解JavaScript提供的for循环。我们将看看for...in循环语句是如何

重学JavaScript Promise API

> 在这篇教程中,我们将掌握如何在JavaScript中创建并使用Promise。我们将了解Promise链式调用、错误处理以及最近添加到语言中的一些Promise静态方法。 ## 什么是Promise? 在JavaScript中,一些操作是异步的。这意味着当这些操作完成时,它们产出的结果或者值并不

如何使用Map处理Dom节点

本文浅析一下为什么`Map`(和WeakMap)在处理大量DOM节点时特别有用。 我们在JavaScript中使用了很多普通的、古老的对象来存储键/值数据,它们处理的非常出色: ```jsx const person = { firstName: 'Alex', lastName: 'MacArth

如何使用 JS 判断用户是否处于活跃状态

有时候,我们需要在网页判断用户是否处与非活跃状态,如果用户长时间没有在页面上进行任何操作,我们则判定该用户是非活跃的。 在 javascript 中我们可以通过监听某些鼠标或键盘相关的事件来判定用户是否在活跃中。

JavaScript中的箭头函数

前言 本文可以让你了解所有有关JavaScript箭头函数的信息。我们将告诉你如何使用ES6的箭头语法,以及在代码中使用箭头函数时需要注意的一些常见错误。你会看到很多例子来说明它们是如何工作的。 JavaScript的箭头函数随着ECMAScript 2015的发布而到来,也被称为ES6。由于其简洁

使用 Promise.withResolvers() 来简化你将函数 Promise 化的实现~~

引言 在JavaScript编程中,Promise 是一种处理异步操作的常用机制。Promise 对象代表了一个尚未完成但预期将来会完成的操作的结果。在本文中,我们将探讨如何通过使用 ES2024 的 Promise.withResolvers API 来优化我们的 Promise 实现。 现有实现

揭秘报表新玩法!标配插件不再单调,如何用柱形图插件让你的报表瞬间高大上!

> 摘要:本文由葡萄城技术团队于博客园原创并首发。葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 # 前言 图表作为一款用于可视化数据的工具,可以帮助我们更好的分析和理解数据,并发现数据之间的关系和趋势。下面以柱形图为例介绍如何使用JavaScript在报表中引入图表。 本文使用软件

async/await初学者指南

> JavaScript中的`async`和`await`关键字提供了一种现代语法,帮助我们处理异步操作。在本教程中,我们将深入研究如何使用`async/await`来掌控JavaScript程序中的流程控制。 > ## 总览 - 如何创建JavaScript异步函数 - async关键字 - aw

JavaScript 如何验证 URL

前言 当开发者需要为不同目的以不同形式处理URL时,比如说浏览器历史导航,锚点目标,查询参数等等,我们经常会借助于JavaScript。然而,它的频繁使用促使攻击者利用其漏洞。这种被利用的风险是我们必须在我们的JavaScript应用程序中实现URL验证的原因。 URL验证检查URL是否遵循正确的U

Vue vs React:你需要知道的一切

Vue 和 React 是创建 JavaScript 网络应用程序最常用的两种工具。但我们该如何在两者之间做出选择呢?在本篇 Vue 与 React 的对比中,我们将尝试找出答案。我们将回顾每种工具的优缺点,提供选择使用哪种工具的技巧,并帮助你开始使用。 总览 什么是Vue? Vue趣事 什么是Re