Tri naturel des chaînes alphanumériques en JavaScript avec LocaleCompare
En JavaScript, trier un tableau contenant un mélange de nombres, de texte et leurs les combinaisons peuvent être un défi. Les algorithmes de tri traditionnels peuvent ne pas gérer ces chaînes comme prévu, ce qui entraîne des résultats incorrects.
Pour de tels cas, les navigateurs fournissent désormais la fonction localeCompare, qui offre des capacités de tri naturelles. En activant l'option numérique, localeCompare peut reconnaître intelligemment les nombres dans les chaînes et les trier en conséquence.
const result = '123asd'.localeCompare('19asd', undefined, { numeric: true, sensitivity: 'base' }); console.log(result); // 1
Dans l'exemple ci-dessus, « 123asd » est considéré comme supérieur à « 19asd » car les nombres sont triés par ordre croissant. commande. L'option de sensibilité est définie sur « base » pour effectuer une comparaison insensible à la casse.
Pour les ensembles de données volumineux, il est recommandé d'utiliser l'objet Intl.Collator au lieu de localeCompare pour des raisons de performances.
const collator = new Intl.Collator(undefined, { numeric: true, sensitivity: 'base' }); const myArray = ['1_Document', '11_Document', '2_Document']; myArray.sort(collator.compare);
Ce tri optimisé garantit un tri naturel précis, gérant efficacement à la fois les chiffres et le texte.
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!