鍍金池/ 問答/HTML/ js 對象數(shù)組push去重復,且push新值,去舊值

js 對象數(shù)組push去重復,且push新值,去舊值

去重復已經(jīng)是實現(xiàn)了了,但是需要去舊的值,加新的值,不是替換舊的值。

比如:[{a:2,c:3},{a:3,c:2}],現(xiàn)在要添加{a:2,c:4}的值,里面a為判斷字段,a都為2,他們重復了,且要從里面去掉數(shù)組第一個值,再push一個新的。

截圖:

clipboard.png

文字代碼:

                    setData.push(str)
                    let obj = {};
                    setData = setData.reduce((cur,next) => {
                        obj[next.receiver] ? (cur[next.receiver] = next.receiver) : obj[next.receiver] = true && cur.push(next);
                        return cur;
                    },[]) //設置cur默認類型為數(shù)組,并且初始值為空的數(shù)組
                    console.log(setData)

"obj[next.receiver] ? "代碼從?后面則是重復值,需要怎么改

回答
編輯回答
過客
let arr = [ { uid: 10002, msg: 'Roshan has fallen to the dire.' }, { uid: 10003, msg: 'Hello, Li Lei. I am Pang Meimo.' } ];

function update(record) {
  let index = 0;
  for(let rec of arr) {  // Search for corresponding record
    if(rec.uid == record.uid) {  // Record matched
      // Delete old record
      arr.splice(index, 1);
    }
    index++;
  }

  arr.push(record);
}

update({ uid: 10002, msg: 'Radiant victory!' });
// [ { uid: 10003, msg: 'Hello, Li Lei. I am Pang Meimo.' },
//   { uid: 10002, msg: 'Radiant victory!' } ]

如果不想這么麻煩,可以修改存儲結構。如果你用的vue那好像也只能這么辦了。

2017年10月3日 11:46