欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS對象去重的多種方式小結(jié)

 更新時間:2024年09月25日 08:50:36   作者:魚櫻前端  
在 JavaScript 中,對象的去重通常是指在一個對象數(shù)組中,根據(jù)某些屬性值去掉重復的對象,本文給大家總結(jié)了一些JS對象去重的多種方式,并通過代碼示例講解的非常詳細,具有一定的參考價值,需要的朋友可以參考下

ES5 方式

在 ES5 中,我們可以使用 for 循環(huán)配合數(shù)組方法來實現(xiàn)對象數(shù)組的去重。

function uniqueArrayByProperty(array, property) {
  var seen = {};
  return array.filter(function(item) {
    var val = item[property];
    return seen.hasOwnProperty(val) ? false : (seen[val] = true);
  });
}

var arr = [
  { id: 1, name: 'Alice' },
  { id: 2, name: 'Bob' },
  { id: 1, name: 'Alice' }, // 重復
  { id: 3, name: 'Charlie' }
];

var uniqueArr = uniqueArrayByProperty(arr, 'id');
console.log(uniqueArr);
// 輸出:[ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 3, name: 'Charlie' } ]

ES6 及之后的方式

隨著 ES6 的引入,有了更多簡潔的方式來處理數(shù)組和對象。

使用 Set 和 JSON.stringify / JSON.parse

這種方法適用于簡單對象,但需要注意 JSON.stringify 會丟失原型鏈上的屬性,而且對于包含循環(huán)引用的對象會拋出錯誤。

function uniqueArrayByPropertyES6(array, property) {
  const seen = new Set();
  return array.filter(item => {
    const val = JSON.stringify(item[property]);
    return seen.has(val) ? false : seen.add(val);
  });
}

var uniqueArrES6 = uniqueArrayByPropertyES6(arr, 'id');
console.log(uniqueArrES6);

使用 Map

對于更復雜的對象去重,可以使用 Map 來存儲已經(jīng)見過的對象。

function uniqueArrayByPropertyWithMap(array, property) {
  const map = new Map();
  return array.filter(item => {
    const val = item[property];
    if (!map.has(val)) {
      map.set(val, true);
      return true;
    }
    return false;
  });
}

var uniqueArrWithMap = uniqueArrayByPropertyWithMap(arr, 'id');
console.log(uniqueArrWithMap);

使用 Map 結(jié)合自定義比較邏輯

這種方法適用于對象具有多個屬性的情況,可以自定義比較邏輯。

function uniqueArrayByProperties(array, properties) {
  const seen = new Map();
  return array.filter(item => {
    const key = properties.map(prop => item[prop]).join('|');
    if (!seen.has(key)) {
      seen.set(key, true);
      return true;
    }
    return false;
  });
}

const arr = [
  { id: 1, name: 'Alice' },
  { id: 2, name: 'Bob' },
  { id: 1, name: 'Alice' }, // 重復
  { id: 3, name: 'Charlie' }
];

const uniqueArr = uniqueArrayByProperties(arr, ['id', 'name']);
console.log(uniqueArr);
// 輸出:[ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 3, name: 'Charlie' } ]

使用 Lodash 庫

Lodash 提供了一個方便的函數(shù) _.uniqBy,可以輕松實現(xiàn)去重。

const _ = require('lodash');

const uniqueArr = _.uniqBy(arr, 'id');
console.log(uniqueArr);
// 輸出:[ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 3, name: 'Charlie' } ]

使用 WeakMap

WeakMap 可以用來存儲對象引用,而不會阻止這些對象被垃圾回收。雖然 WeakMap 的鍵必須是對象,但它可以用來存儲已經(jīng)處理過的對象。

function uniqueArrayByPropertyWithWeakMap(array, property) {
  const seen = new WeakMap();
  return array.filter(item => {
    const val = item[property];
    if (!seen.has(val)) {
      seen.set(val, true);
      return true;
    }
    return false;
  });
}

const uniqueArrWithWeakMap = uniqueArrayByPropertyWithWeakMap(arr, 'id');
console.log(uniqueArrWithWeakMap);
// 輸出:[ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 3, name: 'Charlie' } ]

使用 Set 和 WeakRef (實驗性)

在最新的 JavaScript 版本中,WeakRef 可以用來存儲對象的弱引用,這可以用來輔助對象的去重,但請注意 WeakRef 是一個實驗性功能,可能在未來的版本中有所變化。

const { WeakRef } = require('weakref'); // 假設這是一個支持 WeakRef 的環(huán)境

function uniqueArrayByPropertyWithWeakRef(array, property) {
  const seen = new Set();
  return array.filter(item => {
    const ref = new WeakRef(item[property]);
    if (!seen.has(ref)) {
      seen.add(ref);
      return true;
    }
    return false;
  });
}

const uniqueArrWithWeakRef = uniqueArrayByPropertyWithWeakRef(arr, 'id');
console.log(uniqueArrWithWeakRef);
// 輸出:[ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 3, name: 'Charlie' } ]

使用 Set 結(jié)合 JSON.stringify

對于簡單對象,可以使用 JSON.stringify 來生成對象的字符串表示,然后使用 Set 進行去重。

function uniqueArrayByPropertyWithSet(array, property) {
  const seen = new Set();
  return array.filter(item => {
    const val = JSON.stringify(item[property]);
    return seen.has(val) ? false : seen.add(val);
  });
}

const uniqueArrWithSet = uniqueArrayByPropertyWithSet(arr, 'id');
console.log(uniqueArrWithSet);
// 輸出:[ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 3, name: 'Charlie' } ]

總結(jié)

以上列出了一些實現(xiàn) JavaScript 對象數(shù)組去重的不同方法(項目中經(jīng)常出現(xiàn)這樣的需求數(shù)組對象去重)。選擇哪種方法取決于你的具體需求和環(huán)境。對于簡單的對象,使用 Set 和 JSON.stringify 可能是最簡單的方式;而對于更復雜的情況,使用 Map 或者 WeakMap 可能更合適。如果使用第三方庫,Lodash 的 _.uniqBy 函數(shù)提供了便捷的解決方案。對于實驗性的功能,如 WeakRef,則需要考慮兼容性和穩(wěn)定性問題。

以上就是JS對象去重的多種方式小結(jié)的詳細內(nèi)容,更多關于JS對象去重的資料請關注腳本之家其它相關文章!

相關文章

  • 如何使用uniapp開發(fā)微信小程序獲取當前位置詳解

    如何使用uniapp開發(fā)微信小程序獲取當前位置詳解

    uni-app小程序項目無法直接獲取到地理位置,只能通過獲取到的經(jīng)緯度,調(diào)用第三方地圖Api獲取,下面這篇文章主要給大家介紹了關于如何使用uniapp開發(fā)微信小程序獲取當前位置的相關資料,需要的朋友可以參考下
    2022-10-10
  • 淺談HBuilderX開發(fā)小程序的一些問題

    淺談HBuilderX開發(fā)小程序的一些問題

    本文主要介紹了HBuilderX開發(fā)小程序的一些問題,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • JavaScript導航腳本判斷當前導航

    JavaScript導航腳本判斷當前導航

    這篇文章主要介紹了JavaScript導航腳本判斷當前導航的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-07-07
  • JS實現(xiàn)全屏的四種寫法

    JS實現(xiàn)全屏的四種寫法

    這篇文章主要為大家詳細介紹了JS或jquery實現(xiàn)全屏的四種寫法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • javascript parseInt() 函數(shù)的進制轉(zhuǎn)換注意細節(jié)

    javascript parseInt() 函數(shù)的進制轉(zhuǎn)換注意細節(jié)

    parseInt(string, radix) 有2個參數(shù),第一個string 是傳入的數(shù)值,第二個radix是 傳入數(shù)值的進制,參數(shù)radix 可以忽略,默認為 10,各種進制的數(shù)轉(zhuǎn)換為 十進制整數(shù),接下來詳細介紹,感興趣的朋友可以了解下哦
    2013-01-01
  • Javascript Event(事件)的傳播與冒泡

    Javascript Event(事件)的傳播與冒泡

    本文主要介紹了Event(事件)的傳播與冒泡。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • npm淘寶鏡像修改講解

    npm淘寶鏡像修改講解

    這篇文章主要介紹了npm淘寶鏡像修改講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • TypeScript語法詳解之類型操作的補充

    TypeScript語法詳解之類型操作的補充

    TypeScript最大的一個特點就是變量是強類型的,也就是說在聲明變量的時候我們必須給他一個類型,下面這篇文章主要給大家介紹了關于TypeScript語法詳解之類型操作的補充,需要的朋友可以參考下
    2022-08-08
  • javascript檢測flash插件是否被禁用的方法

    javascript檢測flash插件是否被禁用的方法

    這篇文章主要介紹了javascript檢測flash插件是否被禁用的方法,涉及JavaScript調(diào)用ActiveXObject組件操作flash插件的相關技巧,需要的朋友可以參考下
    2016-01-01
  • Javascript 兩種刷新方法以及區(qū)別和適用范圍

    Javascript 兩種刷新方法以及區(qū)別和適用范圍

    這篇文章主要介紹了Javascript 兩種刷新方法以及區(qū)別和適用范圍的相關資料,需要的朋友可以參考下
    2017-01-01

最新評論