sort()的多种用法

Posted oSHYo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sort()的多种用法相关的知识,希望对你有一定的参考价值。

 sort()  方法用于对数组的元素进行排序。

一、默认情况

在默认情况下, sort() 方法按升序排列数组项。为了实现排序, sort() 方法会调用每个数组项的 toString() 转型方法,然后比较得到的字符串,已确定如何排序。如下:

1 var values = ["orange","apple","banana"];
2 values.sort();
3 console.log(values);//结果["apple", "banana", "orange"]

 

但是,即使数组中的每一项都是数值,sort() 方法比较的也是字符串,如下:

1 var values = [0,1,5,10,15];
2 values.sort();
3 console.log(values);//结果[0, 1, 10, 15, 5]

 

二、对数值进行排序

 sort() 方法可以接收一个比较函数作为参数。

比较函数接收两个参数,如果第一个参数应该位于第二参数之前则返回一个负数,如果两个参数相等则返回0,如果第一个参数位于第二个之后则返回一个正数。

1 function compare(a, b){
2     return (a - b);
3 }//按升序排列的比较函数
4 var values = [0,1,5,10,15];
5 values.sort(compare);
6 console.log(values);//结果[0, 1, 5, 10, 15]

 

三、根据某个对象属性对数组进行排序

先定义一个函数,它接收一个属性名,然后根据这个属性名来创建一个比较函数。下面是这个函数的定义:

 1 function createComparisonFunction(propertyName){
 2     return function(object1, object2){
 3         var a = object1[propertyName];
 4         var b = object2[propertyName];
 5 
 6         if(a < b){
 7             return -1;
 8         }else if(a > b){
 9             return 1;
10         }else{
11             return 0;
12         }
13     }
14 }//返回一个根据属性名创建的按升序排列的比较函数

 

在内部函数接收到propertyName参数后,它会使用方括号表示法来取得给定属性的值。

上面这个函数可以在像在下面例子中这样使用。

1 var data = [{name:"Lily", age: 12}, {name:"Judy", age: 22}];
2 data.sort(createComparisonFunction("name"));
3 console.log(data[0].name);//Judy
4 
5 data.sort(createComparisonFunction("age"));
6 console.log(data[0].name);//Lily

 

以上是关于sort()的多种用法的主要内容,如果未能解决你的问题,请参考以下文章

从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

javascript sort方法和比较函数

C/c++ sort用法

编写一个sort函数,它用于对任何类型的数组进行排序

c语言中sort的用法详解

js中sort()方法的用法,参数以及排序原理