Maison > interface Web > js tutoriel > le corps du texte

Comment trier un tableau 2D par valeur de colonne en JavaScript ?

Barbara Streisand
Libérer: 2024-11-15 19:11:05
original
253 Les gens l'ont consulté

How to Sort a 2D Array by Column Value in JavaScript?

Tri des tableaux 2D en JavaScript

Comment puis-je trier un tableau 2D par valeur de colonne en JavaScript ?

Supposons que nous ayons un tableau 2D au format suivant :

[[12, "AAA"], [58, "BBB"], [28, "CCC"], [18, "DDD"]]
Copier après la connexion

Nous voulons trier ce tableau par la première colonne, ce qui donne :

[[12, "AAA"], [18, "DDD"], [28, "CCC"], [58, "BBB"]]
Copier après la connexion

Solution :

Le tri d'un tableau 2D par valeur de colonne est simple en JavaScript. Voici comment procéder :

var a = [[12, 'AAA'], [58, 'BBB'], [28, 'CCC'],[18, 'DDD']];

a.sort(sortFunction);

function sortFunction(a, b) {
    if (a[0] === b[0]) {
        return 0;
    }
    else {
        return (a[0] < b[0]) ? -1 : 1;
    }
}
Copier après la connexion

Cette fonction utilise les règles suivantes :

  • Si les éléments de la première colonne sont égaux, renvoyez 0.
  • Si l'élément de la première colonne du premier tableau est inférieur à celui du second, renvoie -1.
  • Si l'élément de la première colonne du premier tableau est supérieur à celui du second, renvoie 1.

Pour trier le tableau par la deuxième colonne, remplacez simplement a[0] par a[1] dans la fonction de comparaison.

a.sort(compareSecondColumn);

function compareSecondColumn(a, b) {
    if (a[1] === b[1]) {
        return 0;
    }
    else {
        return (a[1] < b[1]) ? -1 : 1;
    }
}
Copier après la connexion

Référez-vous à la documentation JavaScript pour plus d'informations sur la fonction de tri.

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