Maison > interface Web > js tutoriel > Comment supprimer les valeurs en double d'un tableau JavaScript ?

Comment supprimer les valeurs en double d'un tableau JavaScript ?

Linda Hamilton
Libérer: 2024-12-19 19:03:10
original
1043 Les gens l'ont consulté

How to Remove Duplicate Values from a JavaScript Array?

Supprimer les valeurs en double du tableau JS

Lorsque vous travaillez avec des tableaux JavaScript, il est souvent nécessaire de supprimer les valeurs en double. Plusieurs approches peuvent être utilisées pour y parvenir sans altérer le tableau d'origine.

Utilisation du constructeur Set et de la syntaxe Spread

La méthode la plus simple consiste à utiliser le constructeur Set constructeur et la syntaxe spread :

const uniq = [...new Set(array)];
Copier après la connexion

Cela crée un nouveau Set à partir du tableau, qui supprime automatiquement les doublons. La syntaxe de propagation reconvertit ensuite le Set en tableau.

Filtrage des éléments uniques

Une autre option consiste à filtrer le tableau en fonction de la méthode indexOf :

const uniqueArray = a.filter(function(item, pos) {
    return a.indexOf(item) == pos;
});
Copier après la connexion

Cette méthode parcourt le tableau et vérifie si la première occurrence de chaque élément correspond à sa position. Seuls les éléments uniques satisferont à cette condition.

Hachage avec des objets

Pour plus d'efficacité, le hachage avec des objets peut être utilisé :

function uniq(a) {
    const seen = {};
    return a.filter(function(item) {
        return seen.hasOwnProperty(item) ? false : (seen[item] = true);
    });
}
Copier après la connexion

Cette approche maintient une table de hachage pour vérifier rapidement les valeurs en double, garantissant ainsi un temps linéaire complexité.

Tri et filtrage

Si le tableau d'entrée est trié, il est possible de supprimer les doublons en le triant puis en filtrant les éléments égaux consécutifs :

function uniq(a) {
    return a.sort().filter(function(item, pos, ary) {
        return !pos || item != ary[pos - 1];
    });
}
Copier après la connexion

Unique par coutume Critères

Pour filtrer les doublons en fonction de critères spécifiques, une fonction de rappel peut être utilisée :

function uniqBy(a, key) {
    const seen = {};
    return a.filter(function(item) {
        const k = key(item);
        return seen.hasOwnProperty(k) ? false : (seen[k] = true);
    });
}
Copier après la connexion

La clé de rappel permet des comparaisons personnalisées et permet de supprimer les doublons en fonction de critères plus complexes. logique.

Préserver le premier ou le dernier Occurrence

Dans certains scénarios, il peut être souhaitable de conserver la première ou la dernière occurrence d'éléments en double :

function uniqByKeepFirst(a, key) {
    const seen = new Set();
    return a.filter(item => {
        const k = key(item);
        return seen.has(k) ? false : seen.add(k);
    });
}

function uniqByKeepLast(a, key) {
    return [
        ...new Map(
            a.map(x => [key(x), x])
        ).values()
    ]
}
Copier après la connexion

La fonction uniqByKeepFirst utilise un Set pour conserver les clés uniques. , tandis qu'uniqByKeepLast utilise une Map pour conserver la dernière valeur rencontrée associée à chaque clé.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal