JavaScript多维数组多键值排序方法实现
创始人
2024-07-15 13:21:23
0

你对JavaScript实现多维数组多键值排序方法是否熟悉 ,这里和大家分享一下,JavaScript的数组排序函数sort方法,默认是按照ASCII字符顺序进行升序排列。

JavaScript实现多维数组多键值排序方法

JavaScript的数组排序函数sort方法,默认是按照ASCII字符顺序进行升序排列。

  arrayobj.sort(sortfunction);

参数:sortFunction

  可选项。是用来确定元素顺序的函数的名称。如果这个参数被省略,那么元素将按照ASCII字符顺序进行升序排列。

  sort方法将Array对象进行适当的排序;在执行过程中并不会创建新的Array对象。

  如果为sortfunction参数提供了一个函数,那么该函数必须返回下列值之一:

  负值,如果所传递的***个参数比第二个参数小。

  零,如果两个参数相等。

  正值,如果***个参数比第二个参数大。

  以上的方法在一维的排序还是很方便的,但像SQL语句中的ORDERBY一样的多键值排序由怎么做呢?

  多维数组的多键值排序,则需要复杂一些,但不需要用循环解决。实际解决的道理是一样的。

数字:

  以下的例子是将数字的多维数组按照第5列,第9列,第3列的顺序排序,像SQL语句中的ORDERBYcol5,col9,col7。数字的时候可以直接两个项目相减,以结果作为返回值即可。

  1.  
  2.   varmyArray=newArray();  
  3.   for(vari=0;i<10;i++)...{  
  4.     myArray[i]=newArray();  
  5.     myArray[i][0]=Math.floor(Math.random()*10);      
  6.     myArray[i][1]=Math.floor(Math.random()*10);  
  7.     myArray[i][2]=Math.floor(Math.random()*10);  
  8.     myArray[i][3]=Math.floor(Math.random()*10);  
  9.     myArray[i][4]=Math.floor(Math.random()*10);  
  10.     myArray[i][5]=Math.floor(Math.random()*10);  
  11.     myArray[i][6]=Math.floor(Math.random()*10);  
  12.     myArray[i][7]=Math.floor(Math.random()*10);  
  13.     myArray[i][8]=Math.floor(Math.random()*10);  
  14.   }  
  15.     
  16.   myArray.sort(function(x,y)...{  
  17.     return(x[0]==y[0])?((x[4]==y[4])?(x[8]-y[8]):(x[4]-y[4])):(x[2]-y[2])  
  18.   });  
  19.   for(vari=0;i
  20.     document.write(myArray[i].join(",")+"
    ");  
  21.   }  
  22.  
  23.  

 字符:

  字符的时候sortFunction中的项目不能像数字一样直接相减,需要调用

  str1.localeCompare(str2)方法来作比较,从而满足返回值。以下是多维数组的第1,2列作排序的情况。

  1. functionsortFunction(array)...{  
  2.   returnarray.sort(function(x,y)...{  
  3.   return(x[0]==y[0])?(x[1].localeCompare(y[1])):(x[0].localeCompare(y[0]))  
  4.   });  
  5. }   

       因此arrayObject.sort(sortFunction)的排序功能还是很强大的,终于能够实现了SQL语句中的ORDERBY一样的功能。
 

【编辑推荐】

  1. JavaScript数组元素删除问题解决方案
  2. 解析Javascript中replace()方法使用
  3. C#代码与JavaScript函数的相互调用
  4. JavaScript函数中arguments对象
  5. Javascript中CSS属性float特殊写法

 

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...