JavaScript遍歷對象的五種常用方式總結(jié)
前言
大家好呀!今天我們來聊一聊如何在 JavaScript 中遍歷一個(gè)對象。對象在 JavaScript 中是一個(gè)非常常見的數(shù)據(jù)類型,經(jīng)常用來存儲(chǔ)各種各樣的信息。如何從中提取數(shù)據(jù),或者對每一個(gè)屬性進(jìn)行操作呢?下面我們一起來看看5種常用的遍歷對象的方式吧!
1. for...in 循環(huán)
for...in 是 JavaScript 最常用的一種遍歷對象屬性的方式。它會(huì)遍歷對象所有可枚舉的屬性,包括繼承的屬性。
例子:
const person = {
name: "Alice",
age: 25,
job: "Engineer"
};
for (let key in person) {
console.log(key, ": ", person[key]);
}
輸出:
name : Alice
age : 25
job : Engineer
這里需要注意的是,for...in 會(huì)遍歷對象的所有屬性(包括繼承來的屬性)。如果不希望遍歷繼承的屬性,我們可以加個(gè)判斷:
if (person.hasOwnProperty(key)) {
// 只遍歷 person 自己的屬性
}
2. Object.keys() + forEach() 組合
如果我們只對對象的“自有屬性”感興趣,可以使用 Object.keys() 來獲取所有的鍵(屬性名),然后配合 forEach() 來遍歷。
例子:
const person = {
name: "Alice",
age: 25,
job: "Engineer"
};
Object.keys(person).forEach(key => {
console.log(key, ": ", person[key]);
});
輸出:
name : Alice
age : 25
job : Engineer
Object.keys() 會(huì)返回對象的鍵名數(shù)組,而 forEach() 是數(shù)組的方法,所以可以用它來方便地遍歷每個(gè)鍵。
3. Object.values() + forEach() 組合
如果你只關(guān)心對象的值,可以用 Object.values()。這個(gè)方法會(huì)返回一個(gè)數(shù)組,數(shù)組里包含對象的所有值。
例子:
const person = {
name: "Alice",
age: 25,
job: "Engineer"
};
Object.values(person).forEach(value => {
console.log(value);
});
輸出:
Alice
25
Engineer
4. Object.entries() + forEach() 組合
Object.entries() 會(huì)返回一個(gè)包含對象鍵值對的二維數(shù)組。你可以通過這種方式既得到屬性名,又能得到屬性值,特別適合需要同時(shí)操作鍵和值的場景。
例子:
const person = {
name: "Alice",
age: 25,
job: "Engineer"
};
Object.entries(person).forEach(([key, value]) => {
console.log(key, ": ", value);
});
輸出:
name : Alice
age : 25
job : Engineer
這里 Object.entries(person) 會(huì)返回 [["name", "Alice"], ["age", 25], ["job", "Engineer"]],然后我們可以用解構(gòu)語法([key, value])來方便地訪問鍵和值。
5. for...of + Object.entries() 組合
for...of 循環(huán)是對數(shù)組的遍歷非常友好的一種方法。如果你使用 Object.entries() 得到的是一個(gè)二維數(shù)組,我們可以用 for...of 來遍歷它。
例子:
const person = {
name: "Alice",
age: 25,
job: "Engineer"
};
for (const [key, value] of Object.entries(person)) {
console.log(key, ": ", value);
}
輸出:
name : Alice
age : 25
job : Engineer
for...of 循環(huán)會(huì)讓代碼更簡潔,也能夠更直觀地處理鍵值對。
總結(jié)
for...in:遍歷對象的所有屬性,包括繼承的屬性,但可以通過hasOwnProperty排除繼承的屬性。Object.keys():獲取對象的鍵名數(shù)組,結(jié)合forEach()遍歷。Object.values():獲取對象的值數(shù)組,結(jié)合forEach()遍歷。Object.entries():獲取對象的鍵值對數(shù)組,結(jié)合forEach()或for...of遍歷。
每種方法都有其特定的使用場景哦!你可以根據(jù)具體的需求來選擇最適合的方式。希望這篇文章能幫助你更好地掌握 JavaScript 中的對象遍歷!??
到此這篇關(guān)于JavaScript遍歷對象的五種常用方式的文章就介紹到這了,更多相關(guān)JS遍歷對象五種方式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
e.target與e.currentTarget對象的使用區(qū)別詳解
這篇文章主要為大家介紹了e.target與e.currentTarget的使用區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
微信小程序列表渲染功能之列表下拉刷新及上拉加載的實(shí)現(xiàn)方法分析
這篇文章主要介紹了微信小程序列表渲染功能之列表下拉刷新及上拉加載的實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了微信小程序列表下拉刷新及上拉加載的相關(guān)實(shí)現(xiàn)方法與技巧操作,需要的朋友可以參考下2017-11-11
JavaScript中將字符串轉(zhuǎn)換為浮點(diǎn)數(shù)的技巧
在JavaScript中,parseFloat是一個(gè)內(nèi)置函數(shù),用于將一個(gè)字符串解析成浮點(diǎn)數(shù),這個(gè)方法對于處理用戶輸入、從文本文件讀取數(shù)據(jù)或者在Web API中獲取數(shù)值尤其重要,本文將詳細(xì)介紹parseFloat的工作原理、使用方法以及通過代碼案例展示其在實(shí)際開發(fā)中的應(yīng)用2025-02-02
javascript驗(yàn)證上傳文件的類型限制必須為某些格式
驗(yàn)證上傳文件類型的方法有很多,在本文為大家詳細(xì)介紹下js中是如何實(shí)現(xiàn)的2013-11-11
JavaScript對象字面量和構(gòu)造函數(shù)原理與用法詳解
這篇文章主要介紹了JavaScript對象字面量和構(gòu)造函數(shù),結(jié)合實(shí)例形式分析了JavaScript對象字面量和構(gòu)造函數(shù)相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04

