在 JavaScript 中對物件進行迭代表現形式並移除假屬性
假設我們有一個這樣的 JSON 物件 −
const obj = {
a: {
someKey: {
propOne: '',
enabled: true
}
},
b: {
someKey: {
propOne: '',
enabled: false
}
},
c: {
someKey: {
propOne: '',
enabled: false
}
},
someKey: {
ab: {
propOne: '',
enabled: true
}
}
};我們需要編寫一個 JavaScript 函式,該函式接收一個這樣的物件,並且遞迴地在該物件中移除所有值不實的 "enabled" 屬性。
示例
程式碼如下 −
const obj = {
a: {
someKey: {
propOne: '',
enabled: true
}
},
b: {
someKey: {
propOne: '',
enabled: false
}
},
c: {
someKey: {
propOne: '',
enabled: false
}
},
someKey: {
ab: {
propOne: '',
enabled: true
}
}
};
const deleteFalsyKey = obj => {
const keys = Object.keys(obj);
keys.forEach(key => {
if(obj[key].enabled === false){
delete obj[key];
return;
};
if(obj[key] && typeof obj[key] === 'object'){
deleteFalsyKey(obj[key]);
if (!Object.keys(obj[key]).length) {
delete obj[key];
};
}
});
};
deleteFalsyKey(obj);
console.log(obj);輸出
控制檯中的輸出 −
{
a: { someKey: { propOne: '', enabled: true } },
someKey: { ab: { propOne: '', enabled: true } }
}
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP