Rumah > hujung hadapan web > tutorial js > javascript Sort() 排序详解

javascript Sort() 排序详解

WBOY
Lepaskan: 2016-06-01 09:54:26
asal
1133 orang telah melayarinya

sort() 方法用于对数组的元素进行排序。包含于头文件algorithm

javascript Sort 语法

<code class="language-javascript">arrayObject.sort(sortby)</code>
Salin selepas log masuk
参数 描述
sortby 可选。规定排序顺序。必须是函数。

 

javascript Sort 返回值

对数组的引用。请注意,数组在原数组上进行排序,不生成副本。

 

一、javascript Sort 默认情况

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

<code class="language-javascript">var values = ["orange","apple","banana"];
values.sort();
console.log(values);//结果["apple", "banana", "orange"]</code>
Salin selepas log masuk

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

<code class="language-javascript">var values = [,,,,];
values.sort();
console.log(values);//结果[, , , , ]</code>
Salin selepas log masuk

 

二、javascript Sort 对数值进行排序

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

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

<code class="language-javascript">function compare(a, b){
return (a - b);
}//按升序排列的比较函数
var values = [,,,,];
values.sort(compare);
console.log(values);//结果[, , , , ]</code>
Salin selepas log masuk

 

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

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

<code class="language-javascript">function createComparisonFunction(propertyName){
return function(object, object){
var a = object[propertyName];
var b = object[propertyName];
if(a  b){
return ;
}else{
return ;
}
}
}//返回一个根据属性名创建的按升序排列的比较函数</code>
Salin selepas log masuk

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

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

<code class="language-javascript">var data = [{name:"Lily", age: }, {name:"Judy", age: }];
data.sort(createComparisonFunction("name"));
console.log(data[].name);//Judy
data.sort(createComparisonFunction("age"));
console.log(data[].name);//Lily</code>
Salin selepas log masuk

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan