开发者社区> 前端王睿> 正文

JS数组排序

简介: JS数组排序方法有两个:reverse()和sort(),其中reverse()可将数组进行倒序,而sort()则可将数组项灵活地进行升序或降序排列。
+关注继续查看

JS数组排序方法有两个:reverse()sort(),其中reverse()可将数组进行倒序,而sort()则可将数组项灵活地进行升序或降序排列。

一、reverse()

var arr = [8,4,9,1];

console.log(arr.reverse());   //  [1, 9, 4, 8]
console.log(arr);   //  [1, 9, 4, 8]

可以看出,reverse()会直接改变原数组,并且返回值也是倒序后的数组。

二、sort()

记得当年学C语言时,要学各种各样的排序算法,比如经典的冒泡排序法、二分排序法等,现在抛开这些算法不说,JS就自带原生的排序函数,用起来非常方便,它就是sort()

1. 不传参数

var arr = [8,4,9,1];

console.log(arr.sort());   //  [1, 4, 8, 9]
console.log(arr);   //  [1, 4, 8, 9]

可以看出,sort()不传参数时会按升序方式对数组项进行排序,并且与reverse()一样既改变原数组,同时返回的也是排序后的数组。

我们再来看下一个例子:

var arr = [8,90,9,16];

console.log(arr.sort());  //  [16, 8, 9, 90]

这时你可能会说,不对呀,最终排序返回的不应该是[8, 9, 16, 90]吗?然鹅事实返回的却是[16, 8, 9, 90],这到底是哪门子逻辑?

事实上,sort()并不是按照数值进行排序,而是按字符串字母的ASCII码值进行比较排序的,所以当数组项为数字时,sort()也会自动先将数字转换成字符串,然后再按字母比较的规则进行排序处理。

现在我们再回头看看前面两个例子。当arr[8,4,9,1]时,数组每一项转换成字符串后进行排序的结果正好与数字排序结果相同;而当arr[8,90,9,16]时,数组每一项转换成字符串后就得按顺序一位一位进行比较,比如升序排序时,“16”应该排在最前面,因为“16”的第一位是“1”,比“8”和“9”的ASCII码值都要小。

啰嗦了这么多,其实我们实际很少会使用这种排序方式,而更多的应该就是纯数字的排序。那么我们该如何正确地使用sort()来达到预期的排序效果呢?

接下来就来看看传参后的sort()能给我们怎样的精彩表现。

2. 传入一个函数

这个函数参数功能其实很简单,实际上就是告诉sort()排序方式到底是升序还是降序,我们还是来看具体实例吧~

var arr = [8,90,9,16];

// 升序
console.log(arr.sort(function (a, b) {
    return a - b;
}));    //  [8, 9, 16, 90]

// 降序
console.log(arr.sort(function (a, b) {
    return b - a;
}));   //  [90, 16, 9, 8]

这种用法的规则是,当sort()传入函数中的第一个参数a位于第二个参数b之前,则返回一个负数,相等则返回0,a位于b之后则返回正数。

比如,当要做升序排序时,我们需要想到前面的数肯定是要比后面的数小,所以传入的这个函数参数返回值应该要是个负数,因此函数参数返回a - b

如果实在不好理解,我们可以干脆记下来,a - b升序,b - a降序,但是需要注意的是,如果按照这种记忆方式的话,函数括号内的两个参数ab的书写顺序可不能颠倒哦~

本文重点总结:

① sort() 不传参时默认为升序,且是按字符串比较的方式排序;传参时,其参数为函数,且该函数带俩参数
a 和 b,返回值 a - b 为升序,b - a为降序
② reverse() 和 sort() 两函数均会改变原数组,且返回值同样也是改变后的数组

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
LintCode领扣 题解丨微软高频题:搜索旋转排序数组
LintCode领扣 题解丨微软高频题:搜索旋转排序数组
242 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
19679 0
***PHP 数组排序 +php二维数组排序方法(PHP比较器)
PHP - 一维数组的排序函数 在本节中,我们将学习如下 PHP 数组排序函数: sort() - 以升序对数组排序 rsort() - 以降序对数组排序 asort() - 根据值,以升序对关联数组进行排序 ksort() - 根据键,以升序对关联数组进行排序 arsort() - 根据值,以降序对关联数组进行排序 krsort() - 根据键,以降序对关联数组进行排序   一维数组排序可以使用asort、ksort等一些方法进程排序,相对来说比较简单。
1007 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
24780 0
26. 删除排序数组中的重复项
class Solution { public: int removeDuplicates(vector& nums) { if (nums.
1007 0
算法笔记--基数排序
基数排序是一种数据格式相关的算法,适用范围有限,当数据位数较小时,基数排序法的时间复杂度近似为O(n),效率高于其它的稳定性排序算法。 1. 算法思想           以十进制数为例,现将元素按个位出入一次基数桶,再按十位出入基数桶……直至按最高位出入基数桶,此时序列整体有序。
685 0
艾伟_转载:数组排序方法的性能比较(中):Array.Sort<T> 实现分析
  昨天我们比较了Array.Sort方法与LINQ排序的性能,知道了LINQ排序的性能以较大幅度落后于Array.Sort方法。而对于Array.Sort来说,性能最高的是其中使用Comparer.Default作为比较器的重载方法。
717 0
Java Arrays类进行数组排序
  排序算法,基本的高级语言都有一些提供。C语言有qsort()函数,C++有sort()函数,java语言有Arrays类(不是Array)。用这些排序时,都可以写自己的排序规则。   Java API对Arrays类的说明是:此类包含用来操作数组(比如排序和搜索)的各种方法。
1014 0
+关注
前端王睿
3年Web前端开发工程师,目前就职于上海知名媒体&mdash;&mdash;新闻晨报,个人公众号:前端微站
65
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载