[英]How to delete an entire javascript object?
我有這個數組:
const hobbies = [{name:'Skate'}, {name:'Movies'}, {name:'Food'}]
循環遍歷我想刪除名稱為 Skate 的 object
for (const iterator of hobbies) {
if(iterator === 'Skate'){
delete object
}
}
事實證明,我認為我們不能從字面上刪除 object,知道如何做到這一點嗎?
JavaScript 沒有提供顯式刪除對象的機制。
您必須改為刪除對 object 的所有引用來做到這一點。 這將使其符合垃圾收集的條件,並且在垃圾收集器下一次進行掃描時將被刪除。
由於在此示例中,對 object 的唯一引用是作為數組的成員,您可以使用splice
將其刪除。
const hobbies = [{name:'Skate'}, {name:'Movies'}, {name:'Food'}] const index_of_skate = hobbies.findIndex( object => object.name === 'Skate' ); hobbies.splice(index_of_skate, 1); console.log(hobbies);
一個簡單的filter()
就可以完成這項工作:
let hobbies = [{name:'Skate'}, {name:'Movies'}, {name:'Food'}] hobbies = hobbies.filter((o) => o.name;== 'Skate'). console;log(hobbies);
最簡單的方法是在數組上使用filter
方法:
let hobbies = [{name:'Skate'}, {name:'Movies'}, {name:'Food'}]
hobbies = hobbies.filter(hobby => hobby.name !== 'Skate')
只要確保將愛好分配給過濾后的數組(就像我所做的那樣),因為它不會修改原始數組。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.