Heim >Web-Frontend >js-Tutorial >Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

青灯夜游
青灯夜游nach vorne
2020-11-26 17:44:514217Durchsuche

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

Im gleichen Zeitraum, in dem ECMAScript 2016 im Juni 2016 veröffentlicht wurde, freuen sich JavaScript-Entwickler, dass eine weitere Reihe großartiger Vorschläge Phase 4 (abgeschlossen) erreicht hat.

Anmerkung des Übersetzers: Bei der Übersetzung dieses Artikels wurden diese Funktionen unterstützt.

Lassen Sie uns diese Funktionen auflisten:

新提议包括在2017年要发布的ESMAScript2017标准中,可能会在2017年夏天发布。请注意,这个功能列表可能会一直增长。太好了!

当然,你不必等到ES2017发布,或者直到供应商(浏览器)实现了新功能!Babel已经包含了这些已完成的提案中的大部分特性。

本文主要讨论如何改进对象属性的迭代:

  • 使用Object.values()获取对象属性

  • 使用Object.entries()获取属性key/value

乍一看,这些静态函数似乎并没有带来显著的价值。但是当它们与for...of循环配合使用,你会得到一种简而美的遍历对象的属性的方式。

让我们一探究竟吧。

自己的和可枚举的属性

正如你可能已经知道的那样,Object.keys()只访问对象本身和可枚举的属性。这是合理的,因为大多数时候只有这些属性需要评估。

让我们看一个对象拥有和继承属性的例子。Object.keys()只返回自己的属性键(key):

let simpleColors = {
  colorA: 'white',
  colorB: 'black'
};
let natureColors = {
  colorC: 'green',
  colorD: 'yellow'
};
Object.setPrototypeOf(natureColors, simpleColors);
Object.keys(natureColors); // => ['colorC', 'colorD']
natureColors['colorA'];    // => 'white'
natureColors['colorB'];    // => 'black'

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

Object.keys(natureColors)返回natureColors对象自身和可枚举的属性键:['colorC', 'colorD']natureColors包含从simpleColors原型对象继承的属性。然而,Object.keys()函数会跳过它们。

Object.values()Object.entries()访问对象的属性采用相同的标准:拥有和可枚举属性。让我们来看看:

let simpleColors = {  
    colorA: 'white',
    colorB: 'black'
};
let natureColors = {  
    colorC: 'green',
    colorD: 'yellow'
};

Object.values(natureColors); // => ['green', 'yellow']
Object.entries(natureColors);  // => [ ['colorC', 'green'], ['colorD', 'yellow'] ]

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

现在请注意和for...in不同之处。循环遍历可枚举的自己和继承的属性。下面的例子说明了这一点:

let simpleColors = {  
    colorA: 'white',
    colorB: 'black'
};
let natureColors = {  
    colorC: 'green',
    colorD: 'yellow'
};

let enumerableKeys = [];  
for (let key in natureColors) {  
    enumerableKeys.push(key);
}
enumerableKeys; // => ["colorC", "colorD", "colorA", "colorB"]

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

enumerableKeys数组包含natureColors对象自己属性的键:'colorC''colorD'

此外,for...in遍历从simpleColors原型中继承过来的属性键:'colorA''colorB'

Object.values()返回属性值

为了区分Object.values()的好处,让我们先看看在2017年之前获取对象的属性值是怎么来实现的。

首先使用Object.keys() und Object.entries()

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

Asynchrone Funktion 🎜🎜🎜🎜str.padStart()🎜 und str.padEnd()🎜🎜🎜🎜Object.getOwnPropertyDescriptors()🎜🎜🎜🎜Nachgestellte Kommas (Nachgestellte Kommas)🎜🎜🎜Der neue Vorschlag ist im ESMAScript2017-Standard enthalten, der 2017 veröffentlicht werden soll. Veröffentlicht im Sommer 2017. Bitte beachten Sie, dass diese Funktionsliste möglicherweise weiter wächst. Sehr gut! 🎜🎜 Natürlich müssen Sie nicht warten, bis ES2017 veröffentlicht wird oder bis der Anbieter (Browser) die neuen Funktionen implementiert! Babel🎜 enthält bereits die meisten Funktionen in diesen fertigen Vorschlägen. 🎜🎜In diesem Artikel wird hauptsächlich erläutert, wie die Iteration von Objekteigenschaften verbessert werden kann: 🎜🎜🎜🎜Verwenden Sie Object.values(), um Objekteigenschaften abzurufen. 🎜🎜🎜Verwenden Sie Object.entries () code>Get attribute <code>key/value🎜🎜Auf den ersten Blick scheinen diese statischen Funktionen keinen nennenswerten Wert zu bringen. Wenn sie jedoch in Verbindung mit einer for...of-Schleife verwendet werden, erhalten Sie eine einfache und schöne Möglichkeit, die Eigenschaften eines Objekts zu durchlaufen. 🎜🎜Lass es uns herausfinden. 🎜

Eigene und aufzählbare Eigenschaften

🎜Wie Sie vielleicht bereits wissen, greift Object.keys() nur auf das Objekt selbst und auf aufzählbare Eigenschaften zu. Dies ist sinnvoll, da meist nur diese Eigenschaften bewertet werden müssen. 🎜🎜Sehen wir uns ein Beispiel für ein Objekt an, das Eigenschaften besitzt und erbt. Object.keys() gibt nur seinen eigenen Eigenschaftsschlüssel (key) zurück: 🎜
let meals = {  
    mealA: &#39;Breakfast&#39;,
    mealB: &#39;Lunch&#39;,
    mealC: &#39;Dinner&#39;
};
for (let key of Object.keys(meals)) {  
    let mealName = meals[key];
    // ... do something with mealName
    console.log(mealName); // => &#39;Breakfast&#39; &#39;Lunch&#39; &#39;Dinner&#39;
}
🎜Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS🎜🎜Object.keys(natureColors)Return natureColorsDas Objekt selbst und aufzählbare Eigenschaftsschlüssel: ['colorC', 'colorD']. natureColors enthält Eigenschaften, die vom Prototypobjekt simpleColors geerbt wurden. Die Funktion Object.keys() überspringt sie jedoch. 🎜🎜Object.values() und Object.entries() greifen auf die Eigenschaften eines Objekts zu, indem sie dieselben Kriterien verwenden: eigene und aufzählbare Eigenschaften. Werfen wir einen Blick darauf: 🎜
let meals = {  
    mealA: &#39;Breakfast&#39;,
    mealB: &#39;Lunch&#39;,
    mealC: &#39;Dinner&#39;
};
for (let mealName of Object.values(meals)) {  
    console.log(mealName); // => &#39;Breakfast&#39; &#39;Lunch&#39; &#39;Dinner&#39;
}
🎜2. png 🎜🎜Bitte beachten Sie nun den Unterschied zu for...in. Durchläuft die eigenen und geerbten Eigenschaften der Aufzählung. Das folgende Beispiel veranschaulicht dies: 🎜
let meals = {  
    mealA: &#39;Breakfast&#39;,
    mealB: &#39;Lunch&#39;,
    mealC: &#39;Dinner&#39;
};
for (let [key, value] of Object.entries(meals)) {  
    console.log(key + &#39;:&#39; + value); // => &#39;mealA:Breakfast&#39; &#39;mealB:Lunch&#39; &#39;mealC:Dinner&#39;
}
🎜 3. png🎜🎜enumerableKeys-Array enthält die Schlüssel der eigenen Eigenschaften des natureColors-Objekts: 'colorC' und 'colorD'. 🎜🎜Darüber hinaus iteriert for...in über die vom simpleColors-Prototyp geerbten Eigenschaftsschlüssel: 'colorA' und ' colorB '. 🎜

Object.values() gibt Attributwerte zurück

🎜Um die Vorteile von Object.values() hervorzuheben, schauen wir uns zunächst an, wie man die Attributwerte erhält eines Objekts vor 2017 zu erreichen. 🎜🎜Verwenden Sie zuerst Object.keys(), um die Eigenschaftsschlüssel zu sammeln, verwenden Sie dann einen Eigenschaftsaccessor und speichern Sie den Wert in einer zusätzlichen Variablen. Sehen wir uns ein Beispiel an: 🎜
let greetings = {  
    morning: &#39;Good morning&#39;,
    midday: &#39;Good day&#39;,
    evening: &#39;Good evening&#39;
};
let greetingsMap = new Map(Object.entries(greetings));  
greetingsMap.get(&#39;morning&#39;); // => &#39;Good morning&#39;  
greetingsMap.get(&#39;midday&#39;);  // => &#39;Good day&#39;  
greetingsMap.get(&#39;evening&#39;); // => &#39;Good evening&#39;
🎜🎜🎜

meals是一个普通的JavaScript对象。使用Object.keys(meals)for...of的循环枚举出对象键值。代码看起来很简单,但是可以通过去掉let mealName = meals[key]来优化它。

通过使用Object.values()可以直接访问对象属性值,可以实现优化。优化代码后如下:

let meals = {  
    mealA: &#39;Breakfast&#39;,
    mealB: &#39;Lunch&#39;,
    mealC: &#39;Dinner&#39;
};
for (let mealName of Object.values(meals)) {  
    console.log(mealName); // => &#39;Breakfast&#39; &#39;Lunch&#39; &#39;Dinner&#39;
}

由于Object.values(meals)返回数组中的对象属性值,因此通过for...of循环把对象的属性值直接分配给mealName,因此不需要添加额外的代码,就像前面的例子那样。

Object.values()只做一件事,但做得很好。这也是我们写代码的正确姿势。

Object.entries()返回属性值和键

Object.entries()很强大,它返回对象的键和属性值,而且它们是成对的,比如: [ [key1, value1], [key2, value2], ..., [keyN, valueN] ]

可能直接使用有些不爽。幸运的是,数组在for...of循环中传入let [x, y] = array,很容易得到对应的访问键和值。

下面是Object.entries()的示例:

let meals = {  
    mealA: &#39;Breakfast&#39;,
    mealB: &#39;Lunch&#39;,
    mealC: &#39;Dinner&#39;
};
for (let [key, value] of Object.entries(meals)) {  
    console.log(key + &#39;:&#39; + value); // => &#39;mealA:Breakfast&#39; &#39;mealB:Lunch&#39; &#39;mealC:Dinner&#39;
}

Object.entries(meals)返回meal对象的属性键和值到一个数组中。然后通过for...of循环解构性参数let [key, value]把数组中的值分配给keyvalue变量。

正如所见,访问的键和值现在已经是一种舒适而且易于理解的形式。由于Object.entries()返回一个与数组解构性赋值相兼容的集合,因此没有必要添加额外的赋值或声明行。

Object.entries()将普通对象导入到Map时是有用的。由于Object.entries()返回Map构造函数所接受的格式:keyvalue成对。因此问题变得无关紧要。

让我们创建一个JavaScript对象并将其导出到Map中:

let greetings = {  
    morning: &#39;Good morning&#39;,
    midday: &#39;Good day&#39;,
    evening: &#39;Good evening&#39;
};
let greetingsMap = new Map(Object.entries(greetings));  
greetingsMap.get(&#39;morning&#39;); // => &#39;Good morning&#39;  
greetingsMap.get(&#39;midday&#39;);  // => &#39;Good day&#39;  
greetingsMap.get(&#39;evening&#39;); // => &#39;Good evening&#39;

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

new Map(Object.entries(greetings))构造函数使用一个参数来调用,这个参数是greeting对象中导出的数组的一个键值对。

如预期的那样,map实例greetingsMap包含greetings对象导入的属性。可以使用.get(key)方法访问这些数据。

有趣的是,Map提供了与Object.values()Object.entries()方法相同的方法(只有它们返回迭代器),以便提取Map实例的属性值或键值对:

Map提供了普通对象的改良版。你可以获得Map的大小(对于一个简单的对象,你必须手动操作),并使它作为键或对象类型(简单对象把键当作一个字符串原始类型)。

我们来看看map.values().entries()方法返回什么:

let greetings = {  
    morning: &#39;Good morning&#39;,
    midday: &#39;Good day&#39;,
    evening: &#39;Good evening&#39;
};
let greetingsMap = new Map(Object.entries(greetings));  
[...greetingsMap.values()]; // =>[&#39;Good morning&#39;, &#39;Good day&#39;, &#39;Good evening&#39;]
[...greetingsMap.entries()]; // =>[[&#39;morning&#39;,&#39;Good morning&#39;],
                       [&#39;midday&#39;,&#39;Good day&#39;],[&#39;evening&#39;,&#39;Good evening&#39;]]

Einführung in Methoden zum Durchlaufen von Objekteigenschaften in JS

注意:greetingsMap.values()greetingsMap.entries()返回迭代器对象(Iterator Objects)。将结果放入一个数组,扩展运算符...是必要的。在for...of循环语句中可以直接使用迭代器。

关于顺序上的笔记

JavaScript对象是简单的键值映射。所以对象的属性的顺序是无关紧要的。在大多数情况下,你不应该依赖它。

然而,ES2015已经对迭代的方式提供了标准化的要求:首先是有序的数字字符,然后是插入顺序的字符串,然后是插入顺序的符号(symbols)。在ES5和较早的标准中,属性的顺序没有指定。

如果你需要一个有序的集合,推荐的方法是将数据存储到数组或集合中。

总结

Object.values()Object.entries()是为JavaScript开发人员提供函数的另一个改进步骤的新标准化 。

Object.entries() wird am besten mit Datengruppen-Destrukturierungsparametern ausgeführt, damit Schlüssel und Werte einfach verschiedenen Variablen zugewiesen werden können. Diese Funktion erleichtert auch den Export gewöhnlicher JavaScript-Objekteigenschaften in Map-Objekte. Map kann das herkömmliche Verhalten von map (oder hash) besser unterstützen. Object.entries()最好用数据组解构性参数来执行,这样键和值就可以很容易地分配给不同的变量。这个函数还可以很容易地将普通JavaScript对象属性导出到Map对象中。Map能够更好地支持传统的map(或hash)行为。

注意:object.values()object.entries()

Hinweis: object.values() und object.entries() geben Daten in einer unbestimmten Reihenfolge zurück. Verlassen Sie sich also nicht auf die Reihenfolge.

Englische Originaladresse: https://dmitripavlutin.com/how-to-iterate-easily-over-object-properties-in-javascript/

Übersetzungsadresse: https://www.w3cplus.com/javascript/ how-to-iterate-easily-over-object-properties-in-javascript.html

Weitere Kenntnisse zum Thema Programmierung finden Sie unter: Einführung in die Programmierung

! ! 🎜

Das obige ist der detaillierte Inhalt vonEinführung in Methoden zum Durchlaufen von Objekteigenschaften in JS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:w3cplus.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen