资讯专栏INFORMATION COLUMN

Array.sort排序问题

Yi_Zhi_Yu / 1565人阅读

摘要:比较函数应该具有两个参数和,其返回值如下若小于,在排序后的数组中应该出现在之前,则返回一个小于的值。总结下升序排列,返回值可以简写为降序排序,返回值可以简写为

遇到一个奇葩问题,数组排序在chrome浏览器下没有问题,而在IE下不生效。查了下资料,原来是写法有误。

原来写法:

var arr = [300, 20, 10, 1, 2];
arr.sort(function(a, b){
    return a > b;
});

期望返回值是[300, 20, 10, 2, 1](chrome下),结果是[300, 20, 10, 1, 2](IE下)

比较函数的返回值应该是数字(正数降序,负数升序,0不动),而我写成了bool,导致排序失败。chrome下可能做过兼容处理。

最蛋疼的是,在我写这篇文章时,新版本chrome恢复了,与IE效果成了一样的,而本地nodejs运行的版本(v10.0.0)仍是旧的。

比较函数如果不传,则默认按照字符编码的顺序升序排列。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。

若 a 等于 b,则返回 0。

若 a 大于 b,则返回一个大于 0 的值。

经过测试

比较函数的返回结果如果不是数字(Boolean或者NaN或者String或者Object),都不会排序。

总结下:

升序排列,返回值可以简写为:a-b

降序排序,返回值可以简写为:b-a

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/101473.html

相关文章

  • php 二维数组排序

    摘要:前提给定一个二维数组,请根据指定的数组写出最优的排序。排序条件,指定数组如下估计大家都没有什么问题,排序嘛,简单的不要不要的方式一这应该是最简单的方式了,直接使用现成的函数,快捷的不要不要的。 前提 给定一个二维数组,请根据指定的数组key,写出最优的排序。排序条件age asc,sex desc,指定数组如下: $arr = [ [id=>1, age=>1,...

    ashe 评论0 收藏0
  • 数组排序函数-php数组函数(一)

    摘要:下列的所有排序函数都是直接作用于数组本身,而不是返回一个新的有序的数组。倒序并保持索引关系,按键名排序按键名倒序使用用户自定义的比较函数对数组中的值进行排序,要排序的数组需要用一种不寻常的标准进行排序,那么应该使用此函数。 数组排序,共13个 函数中有u的,能自定义比较函数;有k的,按照键来排序;有r(reverse)的,倒序;有a(association)的,一定是键值关联,除了r...

    call_me_R 评论0 收藏0
  • [笔记] 深入理解 JavaScript Array.sort()

    摘要:以上涉及到一个字符的转换问题,这里不多扩展,写一段代码运行过程做笔记中国代表字符中的第一位,是只有长度的字符输出字符长度为不确定时放入一个数组中。第一次运行后,返回值为,小于,所以的索引值未变化,。 Array.sort() 方法排序,默认为升序排序,如 1,2,3,4 这样的排列,可以传一个对比方法做为排序的参数,也可以不传,则为按照字符的逐个 unicode 排序。 简单默认排序 ...

    QLQ 评论0 收藏0
  • 模拟JavaScript的Array.sort()方法

    摘要:下面重新改写上面的冒泡排序,传递一个回调函数。模拟注意第行和第行,给传递了一个参数,这是一个函数,然后在第行调用,和分别就是回调函数的两个比较值。 在JavaScript中,Array对象的sort()方法是用来排序的,但是这个方法在默认情况下可能不是我们想要的,比如对于如下数组 var arr = [2,5,10,20,7,15]; 使用sort排序会得到如下结果:[10, 15, ...

    liuyix 评论0 收藏0
  • PHP数组多个字段分别排序

    摘要:数组按其中一个字段排序数组个字段排序,先按第一个字段排序,再按第二个字段排序扩展方法最多支持对数组个字段排序,当然可以扩充的自定义方法重载实现对多维数字的排序。 1. PHP数组Array按其中一个字段排序 /** * Sort array by filed and type, common utility method. * @param array $data * @param s...

    liujs 评论0 收藏0
  • [讨论]php 排序系列的函数内部的C实现是用了哪种排序算法?

    摘要:在算法中,比快速排序还快的,无疑是基数排序,粗略看了一下算法,可能是基础排序中的桶排序。桶排序是稳定的桶排序是常见排序里最快的一种,比快排还要快大多数情况下桶排序非常快,但是同时也非常耗空间以空间换时间 ext/standard/php_array.h https://github.com/php/php-src/blob/master/ext/standard/php_array....

    chanthuang 评论0 收藏0

发表评论

0条评论

Yi_Zhi_Yu

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<