數組reduce

reduce的高級用法

計算數組中每個元素出現的次數

const arr = ['tom', 'alice', 'zoey', 'rain', 'tom']
const num = arr.reduce((prev, cur) => {
  if(cur in prev) {
    prev[cur] ++
  } else {
    prev[cur] = 1
  }

  return prev
}, {})
console.log(num); //{tom: 2, alice: 1, zoey: 1, rain: 1}

數組去重

const arr = ['tom', 'alice', 'zoey', 'rain', 'tom']
const newArr = arr.reduce((prev, curr) => {
  if(!prev.includes(curr)) {
    prev.push(curr)
  }
  return prev
}, [])
console.log(newArr); // ["tom", "alice", "zoey", "rain"]

數組扁平化

const arr = [['tom', 'alice'], ['zoey', ['rain', 'tom']]]
const oneDimensionalArr = (arr) => {
  return arr.reduce((prev, curr) => {
    return prev.concat(Array.isArray(curr) ? oneDimensionalArr(curr) : curr)
  }, [])
}
console.log(oneDimensionalArr(arr)); // ["tom", "alice", "zoey", "rain", "tom"]
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。