js中循環(huán)對象

ES6之前,循環(huán)對象常見做法是使用:for...in。但是for...in循環(huán)的問題在于它會遍歷原型鏈中的屬性,所以需要使用hasOwnProperty執(zhí)行檢查屬性是否屬于該對象。
ES6之后,我們對于對象的循環(huán)有了更好的辦法:Object.keys,Object.values,Object.entries

Object.keys :創(chuàng)建一個包含對象所有屬性的數(shù)組
const fruits ={
    appple:22,
    pear:34,
    orange:88
}
var keys = Object.keys(fruits);
console.log(keys);  //["appple", "pear", "orange"]
Object.values:創(chuàng)建一個數(shù)組,其中包含對象中每個屬性的值
const fruits ={
    appple:22,
    pear:34,
    orange:88
}

var values =Object.values(fruits);
console.log(values); //[22, 34, 88]
Object.entries:創(chuàng)建了一個二維數(shù)組,每個內(nèi)部數(shù)組都有2個元素,第一個元素是屬性名,第二個屬性值
const fruits ={
    appple:22,
    pear:34,
    orange:88
}
var entries = Object.entries(fruits);
console.log(entries);
Object.entries.png
使用Object.entries的時候,需要將其內(nèi)部數(shù)組解構(gòu)為其鍵和屬性值
const fruits ={
    appple:22,
    pear:34,
    orange:88
}
for (const [fruit,num] of entries) {
    console.log(`we have ${num} ${fruit}`);  //we have 22 appple ...
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

友情鏈接更多精彩內(nèi)容