WD1X.COM - 问答一下,轻松解决,电脑应用解决专家
主板显卡CPU内存显示器
硬盘维修显卡维修显示器维修
系统注册表系统命令DOSWin8
存储光存储键盘鼠标
内存维修打印机维修
WinXPVistaWin7linux
硬件综合机箱电源/散热器手机数码
主板维修CPU维修键鼠维修网页设计
办公教程ExcelWordPowerPointWPS
网络工具系统工具图像工具
PS教程数据库局域网服务器
PHP教程CSSjavascriptXML

用sort() 给数组及json数据排序

更新时间:2021-06-09 10:49 作者:佚名点击:
var arr = new Array(6)
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
arr[3] = "James"
arr[4] = "Adrew"
arr[5] = "Martin"
 
document.write(arr + "<br />")
document.write(arr.sort())

运行结果:
 
George,John,Thomas,James,Adrew,Martin
 
Adrew,George,James,John,Martin,Thomas
 
 
说明:
 
如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。
 
如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:
 
若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
若 a 等于 b,则返回 0。
若 a 大于 b,则返回一个大于 0 的值。

function sortNumber(a,b)
{
return a - b
}
 
var arr = new Array(6)
arr[0] = "10"
arr[1] = "5"
arr[2] = "40"
arr[3] = "25"
arr[4] = "1000"
arr[5] = "1"
 
document.write(arr + "<br />")
document.write(arr.sort(sortNumber))

运行结果:
10,5,40,25,1000,1
1,10,1000,25,40,5
 
注意:上面的代码没有按照数值的大小对数字进行排序,要实现这一点,就必须使用一个排序函数,如下:

function sortNumber(a,b) //此自定义函数仅仅是个形式而已,函数名和参数都随意自定义
{
return a - b             //不返回给用户,返回给sort()方法;默认为升序,调换a和b的位置则为倒序
}
 
var arr = new Array(6)
arr[0] = "10"
arr[1] = "5"
arr[2] = "40"
arr[3] = "25"
arr[4] = "1000"
arr[5] = "1"
 
document.write(arr + "<br />")
document.write(arr.sort(sortNumber))

运行结果:
10,5,40,25,1000,1
1,5,10,25,40,1000

 

排序json数据

假设取到json数组:sData,其结构如下:

{"ID":1,"NAME":"leeyea"},{"ID":2,"NAME":"mary"},{"ID":3,"NAME":"kitty"}

由于JSON数据输出时一般是无序的,现在需要将数据排序:

一、降序
 

sData.sort( function(a, b){
return parseInt(a["ID" ]) < parseInt(b["ID" ]) ? 1 : parseInt(a[ "ID"]) == parseInt(b[ "ID" ]) ? 0 : -1;

 

});

二、升序

sData.sort( function(a, b){ return parseInt(a["ID" ]) > parseInt(b["ID" ]) ? 1 : parseInt(a[ "ID"]) == parseInt(b[ "ID" ]) ? 0 : -1; });

注:实际操作时,由于js是弱类型语言,被比较的可能是字符串类型,需要进行类型转换,转换成int类型:parseInt()
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
你可能感兴趣的内容