


Können Arrays in ES6 mit for of durchlaufen werden?
Arrays in es6 können mit for of durchlaufen werden. Die „for...of“-Anweisung erstellt eine Schleife zum Iterieren von iterierbaren Objekten. ES6 führt die „for…of“-Schleife ein, um „for…in“ und forEach() zu ersetzen Mit der „for...of“-Anweisung können Entwickler iterierbare Datenstrukturen wie Arrays, Strings, Maps und Sets durchlaufen.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, ECMAScript Version 6, Dell G3-Computer.
Was ist eine for...of-Schleife?
for...of
-Anweisung erstellt eine Schleife, um über ein iterierbares Objekt zu iterieren. Die in ES6 eingeführte for...of
-Schleife ersetzt for...in
und forEach()
und unterstützt ein neues Iterationsprotokoll. Mit for...of
können Sie iterierbare Datenstrukturen wie Arrays, Strings, Maps, Sets usw. durchlaufen. for...of
语句创建一个循环来迭代可迭代的对象。在 ES6 中引入的 for...of
循环,以替代 for...in
和 forEach()
,并支持新的迭代协议。for...of
允许你遍历 Arrays(数组), Strings(字符串), Maps(映射), Sets(集合)等可迭代的数据结构等。
语法
for (variable of iterable) { statement }
- variable:每个迭代的属性值被分配给该变量。
- iterable:一个具有可枚举属性并且可以迭代的对象。
用例
我们来探讨一些用例。
Arrays(数组)
Arrays(数组)就是类列表(list-like)对象。数组原型上有各种方法,允许对其进行操作,比如修改和遍历等操作。下面手在一个数组上进行的 for...of
操作:
// array-example.js const iterable = ['mini', 'mani', 'mo']; for (const value of iterable) { console.log(value); } // Output: // mini // mani // mo
其结果就是打印出 iterable
数组中的每一个值。
Demo: https://jsbin.com/dimahag/edit?js,console
Maps(映射)
Map 对象就是保存 key-value(键值) 对。对象和原始值可以用作 key(键)或 value(值)。Map 对象根据其插入方式迭代元素。换句话说, for...of
循环将为每次迭代返回一个 key-value(键值) 数组。
// map-example.js const iterable = new Map([['one', 1], ['two', 2]]); for (const [key, value] of iterable) { console.log(`Key: ${key} and Value: ${value}`); } // Output: // Key: one and Value: 1 // Key: two and Value: 2
Demo: https://jsbin.com/lofewiw/edit?js,console
Set(集合)
Set(集合) 对象允许你存储任何类型的唯一值,这些值可以是原始值或对象。 Set(集合) 对象只是值的集合。 Set(集合) 元素的迭代基于其插入顺序。 Set(集合) 中的值只能发生一次。如果您创建一个具有多个相同元素的 Set(集合) ,那么它仍然被认为是单个元素。
// set-example.js const iterable = new Set([1, 1, 2, 2, 1]); for (const value of iterable) { console.log(value); } // Output: // 1 // 2
尽管我们的 Set(集合) 有多个 1
和 2
,但输出的只有 1
和 2
。
Demo: https://jsbin.com/fajozob/edit?js,console
String(字符串)
字符串用于以文本形式存储数据。
// string-example.js const iterable = 'javascript'; for (const value of iterable) { console.log(value); } // Output: // "j" // "a" // "v" // "a" // "s" // "c" // "r" // "i" // "p" // "t"
这里,对字符串执行迭代,并打印出每个索引上的字符。
Demo: https://jsbin.com/rixakeg/edit?js,console
Arguments Object(参数对象)
把一个参数对象看作是一个类数组(array-like)对象,并且对应于传递给函数的参数。这是一个用例:
// arguments-example.js function args() { for (const arg of arguments) { console.log(arg); } } args('a', 'b', 'c'); // Output: // a // b // c
你可能会想,发生了什么事?! 如前所述,当调用函数时,arguments
会接收传入 args()
函数的任何参数。所以,如果我们传递 20 个参数给 args()
函数,我们将打印出 20 个参数。
Demo: https://jsbin.com/ciqabov/edit?js,console
Generators(生成器)
生成器是一个函数,它可以退出函数,稍后重新进入函数。
// generator-example.js function* generator(){ yield 1; yield 2; yield 3; }; for (const g of generator()) { console.log(g); } // Output: // 1 // 2 // 3
function*
定义了一个生成器函数,该函数返回生成器对象(Generator object)。更多关于生成器相关的信息,可以点击这里。
Demo: https://jsbin.com/faviyi/edit?js,console
退出迭代
JavaScript 提供了四种已知的终止循环执行的方法:break
、continue
、return
和 throw
。让我们来看一个例子:
const iterable = ['mini', 'mani', 'mo']; for (const value of iterable) { console.log(value); break; } // Output: // mini
在这个例子中,我们使用 break
关键字在一次执行后终止循环,所以只有 mini
被打印出来。
Demo: https://jsbin.com/tisuken/edit?js,console
普通对象不可迭代
for...of
循环仅适用于迭代。 而普通对象不可迭代。 我们来看一下:
const obj = { fname: 'foo', lname: 'bar' }; for (const value of obj) { // TypeError: obj[Symbol.iterator] is not a function console.log(value); }
在这里,我们定义了一个普通对象 obj
,并且当我们尝试 for...of
对其进行操作时,会报错:TypeError: obj[Symbol.iterator] is not a function
Syntax
// object-example.js const obj = { length: 3, 0: 'foo', 1: 'bar', 2: 'baz' }; const array = Array.from(obj); for (const value of array) { console.log(value); } // Output: // foo // bar // baz
- Variable: Der Attributwert jeder Iteration wird dieser Variablen zugewiesen.
- Iterierbar: Ein Objekt, das aufzählbare Eigenschaften hat und iteriert werden kann.
🎜Arrays (array)🎜
🎜Arrays (array) sind listenartige Objekte. Es gibt verschiedene Methoden für den Array-Prototyp, die Operationen darauf ermöglichen, wie z. B. Modifikation und Traversierung. Die folgendefor...of
-Operation wird für ein Array ausgeführt: 🎜//for-in-example.js Array.prototype.newArr = () => {}; Array.prototype.anotherNewArr = () => {}; const array = ['foo', 'bar', 'baz']; for (const value in array) { console.log(value); } // Outcome: // 0 // 1 // 2 // newArr // anotherNewArr
iterable
-Array auszugeben. 🎜🎜Demo: https://jsbin.com/dimahag/edit?js, Konsole🎜Maps (Mapping)
🎜Map-Objekt dient zum Speichern von Schlüssel-Wert-Paaren (Schlüssel-Wert-Paaren). Als Schlüssel oder Werte können Objekte und Grundwerte verwendet werden. Das Kartenobjekt iteriert Elemente basierend darauf, wie sie eingefügt wurden. Mit anderen Worten: Diefor...of
-Schleife gibt für jede Iteration ein Schlüsselwert-Array zurück. 🎜Array.prototype.newArr = () => {}; const array = ['foo', 'bar', 'baz']; for (const value of array) { console.log(value); } // Outcome: // foo // bar // baz
Set(set)
🎜Mit dem Set(set)-Objekt können Sie eindeutige Werte jeder Art speichern. Diese Werte können ein primitiver Wert oder ein Objekt sein. Ein Set-Objekt ist einfach eine Sammlung von Werten. Die Iteration von Set-Elementen basiert auf ihrer Einfügereihenfolge. Ein Wert in einem Set kann nur einmal vorkommen. Wenn Sie ein Set mit mehreren identischen Elementen erstellen, wird es immer noch als einzelnes Element betrachtet. 🎜rrreee🎜Obwohl unser Set mehrere1
und 2
hat, ist die Ausgabe nur 1
und 2
. 🎜🎜Demo: https://jsbin.com/fajozob/edit?js,console🎜String (string)
🎜String wird zum Speichern von Daten in Textform verwendet. 🎜rrreee🎜Hier durchlaufen Sie die Zeichenfolge und geben die Zeichen an jedem Index aus. 🎜🎜Demo: https://jsbin.com/rixakeg/edit?js,console🎜Arguments Object (Parameterobjekt)
🎜Behandeln Sie ein Parameterobjekt als Array-ähnliches Objekt und entspricht den Argumenten an die Funktion übergeben. Hier ist ein Anwendungsfall: 🎜rrreee🎜Sie fragen sich vielleicht, was passiert ist?! Wie bereits erwähnt, empfängtarguments
beim Aufrufen einer Funktion die eingehenden args()
-Parameter der Funktion. Wenn wir also 20 Argumente an die Funktion args()
übergeben, geben wir 20 Argumente aus. 🎜🎜Demo: https://jsbin.com/ciqabov/edit?js,console🎜Generatoren
🎜Ein Generator ist eine Funktion, die die Funktion verlassen und später wieder aufrufen kann. 🎜rrreee🎜function*
definiert eine Generatorfunktion, die ein Generatorobjekt zurückgibt. Weitere Informationen zu Generatoren finden Sie hier. 🎜🎜Demo: https://jsbin.com/faviyi/edit?js, Konsole🎜🎜Iteration beenden🎜🎜JavaScript bietet vier bekannte Methoden zum Beenden der Schleifenausführung: break
, continue code>, <code>return
und throw
. Schauen wir uns ein Beispiel an: 🎜rrreee🎜 In diesem Beispiel verwenden wir das Schlüsselwort break
, um die Schleife nach einer Ausführung zu beenden, sodass nur mini
ausgegeben wird. 🎜🎜Demo: https://jsbin.com/tisuken/edit?js, Konsole🎜🎜Gewöhnliche Objekte sind nicht iterierbar🎜🎜for...of
Schleifen sind nur für die Iteration geeignet. Und gewöhnliche Objekte sind nicht iterierbar. Werfen wir einen Blick darauf: 🎜rrreee🎜Hier definieren wir ein normales Objekt obj
, und wenn wir versuchen, es mit for...of
zu bearbeiten, wird ein Fehler gemeldet :TypeError: obj[Symbol.iterator] ist keine Funktion
. 🎜🎜Demo: https://jsbin.com/sotidu/edit?js,console🎜我们可以通过将类数组(array-like)对象转换为数组来绕过它。该对象将具有一个 length
属性,其元素必须可以被索引。我们来看一个例子:
// object-example.js const obj = { length: 3, 0: 'foo', 1: 'bar', 2: 'baz' }; const array = Array.from(obj); for (const value of array) { console.log(value); } // Output: // foo // bar // baz
Array.from()
方法可以让我通过类数组(array-like)或可迭代对象来创建一个新的 Array(数组) 实例。
Demo: https://jsbin.com/miwofin/edit?js,console
For…of vs For…in
for...in
循环将遍历对象的所有可枚举属性。
//for-in-example.js Array.prototype.newArr = () => {}; Array.prototype.anotherNewArr = () => {}; const array = ['foo', 'bar', 'baz']; for (const value in array) { console.log(value); } // Outcome: // 0 // 1 // 2 // newArr // anotherNewArr
for...in
不仅枚举上面的数组声明,它还从构造函数的原型中查找继承的非枚举属性,在这个例子中,newArr
和 anotherNewArr
也会打印出来。
Demo: https://jsbin.com/quxojof/edit?js,console
for...of
更多用于特定于集合(如数组和对象),但不包括所有对象。
注意:任何具有 Symbol.iterator
属性的元素都是可迭代的。
Array.prototype.newArr = () => {}; const array = ['foo', 'bar', 'baz']; for (const value of array) { console.log(value); } // Outcome: // foo // bar // baz
for...in
不考虑构造函数原型的不可枚举属性。它只需要查找可枚举属性并将其打印出来。
Demo: https://jsbin.com/sakado/edit?js,console
小结
了解 for...of
循环的使用可以在开发过程中节省大量的时间。 希望本文帮助你在JavaScript开发中了解和编写更好的循环结构。 让你快乐编码!
完整的示例代码:https://github.com/codediger/javascript-for-of-loop
【相关推荐:javascript视频教程、编程视频】
Das obige ist der detaillierte Inhalt vonKönnen Arrays in ES6 mit for of durchlaufen werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



So implementieren Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem. Einführung: Mit der kontinuierlichen Weiterentwicklung der Technologie ist die Spracherkennungstechnologie zu einem wichtigen Bestandteil des Bereichs der künstlichen Intelligenz geworden. Das auf WebSocket und JavaScript basierende Online-Spracherkennungssystem zeichnet sich durch geringe Latenz, Echtzeit und plattformübergreifende Eigenschaften aus und hat sich zu einer weit verbreiteten Lösung entwickelt. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem implementieren.

WebSocket und JavaScript: Schlüsseltechnologien zur Realisierung von Echtzeit-Überwachungssystemen Einführung: Mit der rasanten Entwicklung der Internet-Technologie wurden Echtzeit-Überwachungssysteme in verschiedenen Bereichen weit verbreitet eingesetzt. Eine der Schlüsseltechnologien zur Erzielung einer Echtzeitüberwachung ist die Kombination von WebSocket und JavaScript. In diesem Artikel wird die Anwendung von WebSocket und JavaScript in Echtzeitüberwachungssystemen vorgestellt, Codebeispiele gegeben und deren Implementierungsprinzipien ausführlich erläutert. 1. WebSocket-Technologie

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript. Im heutigen digitalen Zeitalter müssen immer mehr Unternehmen und Dienste Online-Reservierungsfunktionen bereitstellen. Es ist von entscheidender Bedeutung, ein effizientes Online-Reservierungssystem in Echtzeit zu implementieren. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Reservierungssystem implementieren, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist WebSocket? WebSocket ist eine Vollduplex-Methode für eine einzelne TCP-Verbindung.

Einführung in die Verwendung von JavaScript und WebSocket zur Implementierung eines Online-Bestellsystems in Echtzeit: Mit der Popularität des Internets und dem Fortschritt der Technologie haben immer mehr Restaurants damit begonnen, Online-Bestelldienste anzubieten. Um ein Echtzeit-Online-Bestellsystem zu implementieren, können wir JavaScript und WebSocket-Technologie verwenden. WebSocket ist ein Vollduplex-Kommunikationsprotokoll, das auf dem TCP-Protokoll basiert und eine bidirektionale Kommunikation zwischen Client und Server in Echtzeit realisieren kann. Im Echtzeit-Online-Bestellsystem, wenn der Benutzer Gerichte auswählt und eine Bestellung aufgibt

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Einführung: Heutzutage ist die Genauigkeit von Wettervorhersagen für das tägliche Leben und die Entscheidungsfindung von großer Bedeutung. Mit der Weiterentwicklung der Technologie können wir genauere und zuverlässigere Wettervorhersagen liefern, indem wir Wetterdaten in Echtzeit erhalten. In diesem Artikel erfahren Sie, wie Sie mit JavaScript und WebSocket-Technologie ein effizientes Echtzeit-Wettervorhersagesystem aufbauen. In diesem Artikel wird der Implementierungsprozess anhand spezifischer Codebeispiele demonstriert. Wir

JavaScript-Tutorial: So erhalten Sie HTTP-Statuscode. Es sind spezifische Codebeispiele erforderlich. Vorwort: Bei der Webentwicklung ist häufig die Dateninteraktion mit dem Server erforderlich. Bei der Kommunikation mit dem Server müssen wir häufig den zurückgegebenen HTTP-Statuscode abrufen, um festzustellen, ob der Vorgang erfolgreich ist, und die entsprechende Verarbeitung basierend auf verschiedenen Statuscodes durchführen. In diesem Artikel erfahren Sie, wie Sie mit JavaScript HTTP-Statuscodes abrufen und einige praktische Codebeispiele bereitstellen. Verwenden von XMLHttpRequest

Verwendung: In JavaScript wird die Methode insertBefore() verwendet, um einen neuen Knoten in den DOM-Baum einzufügen. Diese Methode erfordert zwei Parameter: den neuen Knoten, der eingefügt werden soll, und den Referenzknoten (d. h. den Knoten, an dem der neue Knoten eingefügt wird).

Einführung in die Methode zum Abrufen des HTTP-Statuscodes in JavaScript: Bei der Front-End-Entwicklung müssen wir uns häufig mit der Interaktion mit der Back-End-Schnittstelle befassen, und der HTTP-Statuscode ist ein sehr wichtiger Teil davon. Das Verstehen und Abrufen von HTTP-Statuscodes hilft uns, die von der Schnittstelle zurückgegebenen Daten besser zu verarbeiten. In diesem Artikel wird erläutert, wie Sie mithilfe von JavaScript HTTP-Statuscodes erhalten, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist ein HTTP-Statuscode? HTTP-Statuscode bedeutet, dass der Dienst den Dienst anfordert, wenn er eine Anfrage an den Server initiiert
