6 个用于排序数组的 JavaScript 代码片段

web前端开发

共 1968字,需浏览 4分钟

 ·

2021-11-27 10:43

英文 | https://javascript.plainenglish.io/6-javascript-code-snippets-for-sorting-arrays-56a7049f831

翻译 | 杨小爱


有趣的是,我还没有在 Internet 上找到 JavaScript 中排序行为的完整列表。经过一些考虑,我最终决定创建这样一个内容,作为其他 Web 开发人员的学习参考。 

演示用例:查找“arr”的结果

(1) 数值排序 | 上升 [⇣⁰₉]

const arr = [40, 100, 1, 5, 25, 10];arr.sort(function(a, b){  return a-b;});

之前:[40,100,1,5,25,10]

之后:[1,5,10,25,40,100]

说明:对于数字排序,必须创建 Comparator 实体或比较函数。在上面的代码片段中,这相当于

const compare = function(a, b){  return a-b;};

排序结果是

arr.sort(compare);

(2) 数值排序 | 降序[⇣⁹₀]

const arr = [40, 100, 1, 5, 25, 10];arr.sort(function(a, b){  return b-a; // swap the positions of a and b});

之前:[40,100,1,5,25,10]

之后:[100,40,25,10,5,1]

(3) 字母排序 | 上升✷ [⇣ᴬᴢ]

const arr = ["Blue", "Orange", "Aqua", "Marine"];arr.sort();

之前:[“蓝色”、“橙色”、“水色”、“海洋”]

之后:[“水色”、“蓝色”、“海洋”、“橙色”]

✷字母排序行为在 JavaScript 中不太直观。仅当数组中的所有元素都被读取为(类型)字符串时,内置的默认 sort() 函数才适用于 JavaScript 数组。

(4) 字母排序 | 降序✷ [⇣ᶻᴀ]

const arr = ["Blue", "Orange", "Aqua", "Marine"];arr.sort().reverse();

之前:[“蓝色”、“橙色”、“水色”、“海洋”]

之后:[“橙色”、“海洋”、“蓝色”、“水绿色”]

✷与仅适用于字符串实体的 sort() 函数不同,JavaScript 中的函数 reverse() 适用于整个数组并交换元素的位置而不管(类型)。第一个元素成为最后一个元素,反之亦然。

(5) 日期排序 | 上升 [▲]

const arr = ["2015-03-25", "2015-02-01", "2015-01-03", "2015-02-02"];arr.sort(function(a, b){        return new Date(a)-new Date(b);});

之前:[“2015-03-25”、”2015-02-01”、”2015-01-03”、”2015-02-02”]

之后:[“2015–01–03”、”2015–02–01”、”2015–02–02”、”2015–03–25”]

说明:Date 的排序行为与数字排序非常相似。然而,JavaScript 数组中的 String 实体必须首先被解析为 Date 对象,因为它们可以根据相对日期出现进行排序。

(6) 日期排序 | 降序 [▼]

类似于数字排序...

const arr = ["2015-03-25", "2015-02-01", "2015-01-03", "2015-02-02"];arr.sort(function(a, b){        return new Date(b)-new Date(a); // swap the positions of a and b});

之前:[“2015-03-25”、”2015-02-01”、”2015-01-03”、”2015-02-02”]

之后:[“2015–03–25”、”2015–02–02”、”2015–02–01”、”2015–01–03”]

总结

这就是我对 JavaScript 数组进行排序的 6 个代码片段列表的总结!非常感谢您坚持阅读到本文的结尾。

希望您发现这很有用,并考虑将其加入收藏书签以供需要时参考。

最后,祝编程愉快!



学习更多技能

请点击下方公众号

浏览 27
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报