![](/img/trans.png)
[英]How to remove unmatched objects from array of objects using javascript or lodash
[英]How to remove Objects from an array of objects using JavaScript?
我有一個對象數組,其中一些對象未定義,我想知道如何刪除它們,我知道它們中有多少,但不知道如何從對象數組中刪除它們。 我知道使用這種方法,但我想要一些更標准的方法來做到這一點
const data = [
{
roleDoc:{
name:"A"
}
},
{ roleDoc: undefined }
,{
roleDoc:{
name:"c"
}
},{
roleDoc:{
name:"c"
}
},
{ roleDoc: undefined },
,{
roleDoc:{
name:"c"
}
}
]
const xy = []
data.forEach(item => {
if(item.roleDoc !== undefined){
xy.push(item)
}
else{
console.log('hello')
}
})
console.log(xy)
預期輸出是
const data = [
{
roleDoc: {
name: "A"
}
},
,
{
roleDoc: {
name: "c"
}
},
{
roleDoc: {
name: "c"
}
},
,
{
roleDoc: {
name: "c"
}
}
];
您可以使用.filter()
刪除undefined
的。
請嘗試以下操作:
const data = [{ roleDoc:{ name:"A" } }, { roleDoc: undefined } ,{ roleDoc:{ name:"c"}},{roleDoc:{name:"c"} }, { roleDoc: undefined },{ roleDoc:{name:"c"}}]; const result = data.filter(e => e.roleDoc); console.log(result);
我希望這有幫助!
你可以用Array#filter
和!!
只匹配有效
const data = [ { roleDoc:{ name:"A" } }, { roleDoc: undefined } ,{ roleDoc:{ name:"c" } },{ roleDoc:{ name:"c" } }, { roleDoc: undefined },{ roleDoc:{ name:"c" } }]; let res = data.filter(a=> !!a.roleDoc); console.log(res)
您可以使用使用Array.filter
函數的函數編程方法:
const data = [
{
roleDoc: {
name: "A"
}
},
{
roleDoc: undefined
},
{
roleDoc: {
name: "c"
}
},
{
roleDoc: {
name: "c"
}
},
{
roleDoc: undefined
},
{
roleDoc: {
name: "c"
}
}
];
const arrayWithoutUndefineds = data.filter(el => typeof el.roleDoc !== 'undefined');
console.log(arrayWithoutUndefineds);
請注意,可以簡化所使用的表達式。 然而,所以很清楚發生了什么我會把它留在那里。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.