如何使用JavaScript將具有相同ID的數組元素合併到一個對像中?
JavaScript數組元素合併:將相同ID的元素合併到一個對像中
在數據處理中,經常需要將具有相同ID的數組元素合併成單個對象。本文提供一種JavaScript解決方案,將具有相同ID但屬性不同的數組元素,轉換成新的數組格式。
原始數據格式:
const list = [ { id: "202301", jine: 23, type: "晚餐" }, { id: "202301", jine: 87.5, type: "早餐" }, { id: "202301", jine: 1065.5, type: "中餐" }, { id: "202302", jine: 10, type: "晚餐" }, { id: "202302", jine: 181.5, type: "早餐" }, { id: "202302", jine: 633.5, type: "中餐" } ];
目標數據格式:
const targetList = [ { id: "202301", jine1: 87.5, jine2: 1065.5, jine3: 23 }, { id: "202302", jine1: 181.5, jine2: 633.5, jine3: 10 } ];
解決方案:
我們將使用reduce
方法實現數據轉換。該方法迭代數組,將每個元素累積到一個結果對像中。
const result = Object.values(list.reduce((acc, curr) => { const { id, jine, type } = curr; if (!acc[id]) { acc[id] = { id }; } switch (type) { case '早餐': acc[id].jine1 = jine; break; case '中餐': acc[id].jine2 = jine; break; case '晚餐': acc[id].jine3 = jine; break; } return acc; }, {})); console.log(result); // 輸出目標數據格式
代碼解釋:
-
reduce
方法:reduce
方法迭代list
數組,將每個元素累積到一個對象acc
中。 -
acc[id]
:使用id
作為鍵,將數據存儲到acc
對像中。如果id
不存在,則創建一個新的對象。 -
switch
語句:根據type
屬性的值,將jine
值分別賦值給jine1
、jine2
或jine3
。 -
Object.values
:最後,使用Object.values
方法將acc
對象轉換為數組,得到目標數據格式。
此方法清晰簡潔,避免了使用外部庫,直接利用JavaScript內置方法實現數據轉換。 它也更易於擴展,如果需要處理更多類型的餐飲,只需在switch
語句中添加更多case
即可。
以上是如何使用JavaScript將具有相同ID的數組元素合併到一個對像中?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Java中文亂碼問題主要由字符編碼不一致導致,修復方法包括確保系統編碼一致性和正確處理編碼轉換。 1.統一使用UTF-8編碼,從文件到數據庫和程序。 2.讀取文件時明確指定編碼,如使用BufferedReader和InputStreamReader。 3.設置數據庫字符集,如MySQL使用ALTERDATABASE語句。 4.HTTP請求和響應中設置Content-Type為text/html;charset=UTF-8。5.注意編碼一致性、轉換和調試技巧,確保正確處理數據。

Linux系統通過ulimit命令限制用戶資源,防止資源過度佔用。 1.ulimit是shell內置命令,可限製文件描述符數(-n)、內存大小(-v)、線程數(-u)等,分為軟限制(當前生效值)和硬限制(最高上限)。 2.臨時修改直接使用ulimit命令,如ulimit-n2048,但僅對當前會話有效。 3.永久生效需修改/etc/security/limits.conf及PAM配置文件,並添加sessionrequiredpam_limits.so。 4.systemd服務需在unit文件中設置Lim

中間件是Laravel中的過濾機制,用於攔截和處理HTTP請求。使用步驟:1.創建中間件:使用命令“phpartisanmake:middlewareCheckRole”。 2.定義處理邏輯:在生成的文件中編寫具體邏輯。 3.註冊中間件:在Kernel.php中添加中間件。 4.使用中間件:在路由定義中應用中間件。

Laravel的页面缓存策略可以显著提升网站性能。1)使用cache辅助函数实现页面缓存,如Cache::remember方法。2)选择合适的缓存后端,如Redis。3)注意数据一致性问题,可使用细粒度缓存或事件监听器清除缓存。4)结合路由缓存、视图缓存和缓存标签进一步优化。通过合理应用这些策略,可以有效提升网站性能。

隨著互聯網的蓬勃發展,韓漫(韓國漫畫)以其精美的畫風、引人入勝的劇情和豐富多樣的題材,贏得了全球範圍內越來越多讀者的喜愛。想要隨時隨地暢遊在精彩的韓漫世界中,找到一個穩定、免費且資源豐富的在線閱讀平台至關重要。本文將為您提供一份詳盡的韓漫在線觀看免費漫畫入口指南,助您輕鬆開啟您的韓漫之旅。

Redis主從復制故障的排查與修復步驟包括:1.檢查網絡連接,使用ping或telnet測試連通性;2.檢查Redis配置文件,確保replicaof和repl-timeout設置正確;3.查看Redis日誌文件,查找錯誤信息;4.如果是網絡問題,嘗試重啟網絡設備或切換備用路徑;5.如果是配置問題,修改配置文件;6.如果是數據同步問題,使用SLAVEOF命令重新同步數據。

Redis集群節點故障的快速定位與處理步驟如下:1.確認故障:使用CLUSTERNODES命令查看節點狀態,若顯示fail則節點故障。 2.確定原因:檢查網絡、硬件和配置,常見問題包括內存限制超出。 3.修復與恢復:根據原因採取措施,如重啟服務、更換硬件或修正配置。 4.注意事項:確保數據一致性,選擇合適的故障轉移策略,建立監控與告警系統。

Java中的異常分為三種:受檢異常、非受檢異常和錯誤。 1.受檢異常需在代碼中處理或聲明拋出,如IOException。 2.非受檢異常由邏輯錯誤引起,如NullPointerException,不需強制處理。 3.錯誤如OutOfMemoryError,通常不可恢復。
