JavaScript修改、刪除數(shù)組中某個對象的某個屬性幾種方法
一 有幾種方法可以用來修改JavaScript數(shù)組中對象的屬性:
- 使用Array.map()方法
- 使用for-of循環(huán)
- 使用具有擴展運算符的Array.map()方法
- 使用forEach()方法
- 使用find()方法和解構。
方法1:使用Array.map()方法
使用map()方法根據(jù)指定的函數(shù),通過轉換原始數(shù)組的每個元素來創(chuàng)建一個新的數(shù)組。
let employees_data = [ { employee_id: 1, employee_name: "Aman", }, { employee_id: 2, employee_name: "Bhargava", }, { employee_id: 3, employee_name: "Chaitanya", }, ]; const modifiedEmployees = employees_data.map(obj => { if (obj.employee_id === 2) { return { ...obj, employee_name: "rahul" }; } return obj; }); console.log(modifiedEmployees);
輸出
[
{ employee_id: 1, employee_name: 'Aman' },
{ employee_id: 2, employee_name: 'rahul' },
{ employee_id: 3, employee_name: 'Chaitanya' }
]
方法2:使用for-of循環(huán)
使用for循環(huán)遍歷一個包含對象的數(shù)組,根據(jù)條件查找并修改特定對象的屬性。
let employees_data = [ { employee_id: 1, employee_name: "Aman", }, { employee_id: 2, employee_name: "Bhargava", }, { employee_id: 3, employee_name: "Chaitanya", }, ]; for (let object of employees_data) { if (object.employee_id === 2) { object.employee_name = "Anthony"; } } console.log("Updated Data: "); console.log(employees_data);
輸出
Updated Data:
[
{ employee_id: 1, employee_name: 'Aman' },
{ employee_id: 2, employee_name: 'Anthony' },
{ employee_id: 3, employee_name: 'Chaitanya' }
]
方法3:使用Array.map()與擴展運算符
使用Array.map()創(chuàng)建一個帶有擴展運算符的新數(shù)組,以修改特定對象的屬性。
employees_data.map((employee) => { if (employee.employee_id === 2) { return { ...employee, employee_name: "Anthony", }; } return employee; });
示例: 在這個示例中,我們將使用Array.map()方法以及spread operator(…)將對象自身展開,以便通過使用先前創(chuàng)建的對象數(shù)組來更新現(xiàn)有對象的屬性值。
let employees_data = [ { employee_id: 1, employee_name: "Aman", }, { employee_id: 2, employee_name: "Bhargava", }, { employee_id: 3, employee_name: "Chaitanya", }, ]; let new_updated_data = employees_data.map((employee) => { if (employee.employee_id === 2) { return { ...employee, employee_name: "Anthony", }; } return employee; }); console.log("Updated Data: "); console.log(new_updated_data);
輸出
Updated Data:
[
{ employee_id: 1, employee_name: 'Aman' },
{ employee_id: 2, employee_name: 'Anthony' },
{ employee_id: 3, employee_name: 'Chaitanya' }
]
方法4:使用 forEach() 方法
使用 forEach() 方法,遍歷對象數(shù)組,檢查條件并修改匹配對象的屬性
let employees_data = [ { employee_id: 1, employee_name: "Aman", }, { employee_id: 2, employee_name: "Bhargava", }, { employee_id: 3, employee_name: "Chaitanya", }, ]; const modifyProperty = (arr, targetId, newProperty) => { arr.forEach(obj => { if (obj.employee_id === targetId) { obj.employee_name = newProperty; } }); }; modifyProperty(employees_data, 2, "Ankit"); console.log(employees_data);
[ { employee_id: 1, employee_name: 'Aman' }, { employee_id: 2, employee_name: 'Ankit' }, { employee_id: 3, employee_name: 'Chaitanya' } ]
方法5:使用find()方法和解構
使用find()方法搜索具有指定屬性值的對象,并使用解構修改屬性。
let employees_data = [ { employee_id: 1, employee_name: "Aman", }, { employee_id: 2, employee_name: "Bhargava", }, { employee_id: 3, employee_name: "Chaitanya", }, ]; const modifyProperty = (arr, targetId, newProperty) => { const targetObj = arr.find(obj => obj.employee_id === targetId); if (targetObj) { targetObj.employee_name = newProperty; } }; modifyProperty(employees_data, 2, "Kavita"); console.log(employees_data);
[ { employee_id: 1, employee_name: 'Aman' }, { employee_id: 2, employee_name: 'Kavita' }, { employee_id: 3, employee_name: 'Chaitanya' } ]
二 JavaScript刪除數(shù)組對象中的某個對象里的某個屬性
方法1:使用for循環(huán)
let employ = [ { employid: 1, employname: "Aman", employage:"15" }, { employee_id: 2, employee_name: "Bhargava", employage:"16" }, { employee_id: 3, employee_name: "Chaitanya", employage:"17" }, ]; for(var i =0;i<employ.length;i++){ if(employ[i].employid===1){ delete employ[i].employage }} console.log(employ) 輸出: [ { employid: 1, employname: "Aman", }, { employee_id: 2, employee_name: "Bhargava", employage:"16" }, { employee_id: 3, employee_name: "Chaitanya", employage:"17" }, ];
可以看到上面打印輸出第一條對象里的年齡屬性刪除了
總結
到此這篇關于JavaScript修改、刪除數(shù)組中某個對象的某個屬性幾種方法的文章就介紹到這了,更多相關JS修改、刪除數(shù)組某個屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
js如何實現(xiàn)小程序wx.arrayBufferToBase64方法實例
這篇文章主要給大家介紹了關于js如何實現(xiàn)小程序wx.arrayBufferToBase64方法的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2022-03-03javascript中定義私有方法說明(private method)
本篇文章主要是對javascript中定義私有方法(private method)進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01新浪微博字數(shù)統(tǒng)計 textarea字數(shù)統(tǒng)計實現(xiàn)代碼
從新浪微博代碼里抄的,非常不錯,需要的朋友可以參考下。2011-08-08js正則表達式最長匹配(貪婪匹配)和最短匹配(懶惰匹配)用法分析
這篇文章主要介紹了js正則表達式最長匹配(貪婪匹配)和最短匹配(懶惰匹配)用法,結合實例形式分析了貪婪匹配與懶惰匹配的具體用法與相關注意事項,需要的朋友可以參考下2016-12-12