首頁 >web前端 >js教程 >JS中遍歷物件屬性的方法介紹

JS中遍歷物件屬性的方法介紹

青灯夜游
青灯夜游轉載
2020-11-26 17:44:514255瀏覽

JS中遍歷物件屬性的方法介紹

在2016年6月發布的ECMAScript 2016的同一時期,令JavaScript開發人員開心的是知道另一組很棒的提案已經達到了第4階段(完成)。

譯者註:在翻譯這篇文章時,這幾個特性已得到了支持。

讓我們列出這些功能:

#新提案包括在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'

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'] ]

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"]

JS中遍歷物件屬性的方法介紹

enumerableKeys陣列包含natureColors物件自己屬性的鍵:'colorC''colorD'

此外,for...in遍歷從simpleColors原型中繼承過來的屬性鍵:'colorA'' colorB'

Object.values()傳回屬性值

為了區分Object.values()的好處,讓我們先來看看在2017年之前取得物件的屬性值是怎麼來實現的。

首先使用Object.keys()來收集屬性鍵,然後使用屬性存取器,並將值儲存在額外的變數中。讓我們來看一個例子:

let meals = {  
    mealA: 'Breakfast',
    mealB: 'Lunch',
    mealC: 'Dinner'
};
for (let key of Object.keys(meals)) {  
    let mealName = meals[key];
    // ... do something with mealName
    console.log(mealName); // => 'Breakfast' 'Lunch' 'Dinner'
}

JS中遍歷物件屬性的方法介紹

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

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

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

由于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: 'Breakfast',
    mealB: 'Lunch',
    mealC: 'Dinner'
};
for (let [key, value] of Object.entries(meals)) {  
    console.log(key + ':' + value); // => 'mealA:Breakfast' 'mealB:Lunch' 'mealC:Dinner'
}

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

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

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

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

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

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: 'Good morning',
    midday: 'Good day',
    evening: 'Good evening'
};
let greetingsMap = new Map(Object.entries(greetings));  
[...greetingsMap.values()]; // =>['Good morning', 'Good day', 'Good evening']
[...greetingsMap.entries()]; // =>[['morning','Good morning'],
                       ['midday','Good day'],['evening','Good evening']]

JS中遍歷物件屬性的方法介紹

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

关于顺序上的笔记

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

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

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

总结

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

Object.entries()最好用資料組解構性參數來執行,這樣鍵和值就可以很容易地分配給不同的變數。這個函數也可以很容易地將普通JavaScript物件屬性匯出到Map物件中。 Map能夠更好地支援傳統的map(或hash)行為。

注意:object.values()object.entries()傳回資料的順序是未確定的。所以不要依賴順序。

英文原文網址:https://dmitripavlutin.com/how-to-iterate-easily-over-object-properties-in-javascript/

譯文地址:https: //www.w3cplus.com/javascript/how-to-iterate-easily-over-object-properties-in-javascript.html

更多程式相關知識,請造訪:程式設計入門! !

以上是JS中遍歷物件屬性的方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:w3cplus.com。如有侵權,請聯絡admin@php.cn刪除