JavaScript深入理解sort()方法

作者: 后除 | 来源:发表于2017-11-17 16:05 被阅读38次

一. 基本用法

let arr1 = [3, 5, 7, 1, 8, 7, 10, 20, 19]
console.log(arr1.sort())
// [1, 10, 19, 20, 3, 5, 7, 7, 8]

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

其实,在使用sort()进行排序的时候会调用toString()函数将其值转换成字符串在进行比较,是按ASCII进行比较的。

于是,在比较数字时会转换成字符串再比较,结果就会不准确。

二. 改进用法

let arr1 = [3, 5, 7, 1, 8, 7, 10, 20, 19]
console.log(arr1.sort(function (a, b) {
    if (a < b) {
        return -1
    }
    if (a > b) {
        return 1
    }
    return 0
}))
// [1, 3, 5, 7, 7, 8, 10, 19, 20]
console.log(arr1.sort(function (a, b) {
    return a - b
}))
// [1, 3, 5, 7, 7, 8, 10, 19, 20]

sort()同时也是一个高阶函数,里面可以放一个比较函数:arr.sort(compareFunction)

arr.sort(function (a, b) {
    return ?
})
  • 若compareFunction返回值小于0,a排在b前面,即a与b的位置不变。
  • 若compareFunction返回值等于0,a与b的位置不变。
  • 若compareFunction返回值大于0,a排在b的后面,即a与b的位置交换。

即若返回值大于0的时候交换a与b的位置,其他情况位置不变。

  • 升序:return a - b
  • 降序:return b - a
// 降序示例
let arr1 = [3, 5, 7, 1, 8, 7, 10, 20, 19]
console.log(arr1.sort(function (a, b) {
    return b - a
}))
// [20, 19, 10, 8, 7, 7, 5, 3, 1]
console.log(arr1.sort((a, b) => {
    return b - a
}))
// [20, 19, 10, 8, 7, 7, 5, 3, 1]

三. 比较数组中的对象

let arr2 = [
    {
        name: 'mazey0',
        value: 3
    },
    {
        name: 'mazey1',
        value: 5
    },
    {
        name: 'mazey2',
        value: 7
    },
    {
        name: 'mazey3',
        value: 1
    },
    {
        name: 'mazey4',
        value: 10
    },
    {
        name: 'mazey5',
        value: 7
    }
]
// 升序
let arr3 = arr2.sort((a, b) => {
    return a.value - b.value
})
arr3.forEach((value, index, arr) => {
    console.log(value.value)
})
// 1 3 5 7 7 10

相关文章

  • JavaScript深入理解sort()方法

    一. 基本用法 如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺...

  • JavaScript中sort()方法理解

    sort() 方法用于对数组的元素进行排序 sort可以传入参数,也可以不传参数,下面分别说明。 不带参数 排序前...

  • 数组排序

    JavaScript的sort()方法 sort()方法按照升序排列数组项,会调用每个数组项的toString()...

  • 深入了解javascript的sort方法

    写于2015年6月18日,可能已过时,请谨慎参考。所有示例代码未经完整测试,仅示意思路。 在javascript中...

  • sort方法深入

    判断回调函数的返回值,若大于0则前后交换位置,小于或等于0位置不动 返回1,大于0,则每一次的前后都要交换顺序,相...

  • JavaScript sort() 方法

    定义和用法 sort() 方法用于对数组的元素进行排序。 语法 arrayObject.sort(sortby) ...

  • Javascript sort() 方法

    突然需要对数组进行排序,然后才又回过头来温习这东西,真的超久没用到了…(⊙_⊙;)…按照习惯通过看例子进行了解吧。...

  • javascript函数,以及闭包的理解

    javascript函数,以及闭包的理解 深入理解javascript函数定义与函数作用域深入理解javascri...

  • JavaScript 中的数组去重和排序

    排序 Sort方法 在JavaScript中,数组Array本身有具有Sort方法可以对数组的元素进行排序,并返回...

  • 几个有用的 JavaScript 技巧

    1.对数字数组进行排序 JavaScript 数组有内置的 sort 方法。默认情况下 sort 方法把数组元素转...

网友评论

    本文标题:JavaScript深入理解sort()方法

    本文链接:https://www.haomeiwen.com/subject/zzdjvxtx.html