亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

ES6 根據字符串值創建單獨的數組

ES6 根據字符串值創建單獨的數組

森林海 2021-09-30 15:11:17
我有一個包含以下數據的數組:[ { download: 'Test1', user: '[email protected]' },  { download: 'Test2', user: '[email protected]' },  { download: 'Test1', user: '[email protected]' },  { download: 'Test1', user: '[email protected]' }]我正在嘗試基于download字符串創建 2 個數組。因此,例如一個數組:[ { download: 'Test1', user: '[email protected]' },  { download: 'Test1', user: '[email protected]' },  { download: 'Test1', user: '[email protected]' }]和另一個數組:[  { download: 'Test2', user: '[email protected]' },]這樣做的最佳方法是什么?我不能通過做 a 來過濾,download === 'Test2'因為download字符串總是會改變并且不同。這會是一份工作.reduce()嗎?
查看完整描述

1 回答

?
喵喔喔

TA貢獻1735條經驗 獲得超5個贊

您可以使用 reduce 和 object 作為累加器,基于下載屬性值的俱樂部元素


let data = [ { download: 'Test1', user: '[email protected]' },{ download: 'Test2', user: '[email protected]' },{ download: 'Test1', user: '[email protected]' },{ download: 'Test1', user: '[email protected]' }]


let final = data.reduce( (op,inp) => {

  let {download}  = inp

  op[download] = op[download] || []

  op[download].push(inp)

  return op

},{})


console.log(final)


查看完整回答
反對 回復 2021-09-30
  • 1 回答
  • 0 關注
  • 193 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號