标题:JavaScript:多维数组像ORDER BY一样实现多键值排序 出处:BIWEB开源PHP WMS系统创始人ArthurXF肖飞的blog 时间:Mon, 05 Nov 2012 13:28:48 +0000 作者:ArthurXF 地址:http://www.bizeway.net/read.php/612.htm 内容: JavaScript的数组排序函数 sort方法,默认是按照ASCII 字符顺序进行升序排列。 arrayobj.sort(sortfunction); 参数:sortFunction 可选项。是用来确定元素顺序的函数的名称。如果这个参数被省略,那么元素将按照 ASCII 字符顺序进行升序排列。 sort 方法将 Array 对象进行适当的排序;在执行过程中并不会创建新的 Array 对象。 如果为 sortfunction 参数提供了一个函数,那么该函数必须返回下列值之一: 负值,如果所传递的第一个参数比第二个参数小。 零,如果两个参数相等。 正值,如果第一个参数比第二个参数大。 以上的方法在一维的排序还是很方便的,但像SQL语句中的ORDER BY 一样的多键值排序由怎么做呢? 多维数组的多键值排序,则需要复杂一些,但不需要用循环解决。实际解决的道理是一样的 。 数字: 以下的例子是将数字的多维数组按照第5列,第9列,第3列的顺序排序,像SQL语句中的ORDER BY  col5,col9,col7。数字的时候可以直接两个项目相减,以结果作为返回值即可。 字符: 字符的时候sortFunction中的项目不能像数字一样直接相减,需要调用str1.localeCompare( str2 )方法来作比较,从而满足返回值。以下是多维数组的第1,2列作排序的情况。 function sortFunction(array) ...{    return array.sort( function(x, y) ...{return (x[0]==y[0])?(x[1].localeCompare(y[1])):(x[0].localeCompare(y[0]))});} 因此arrayObject.sort( sortFunction )的排序功能还是很强大的,终于能够实现了SQL语句中的ORDER BY 一样的功能。 Generated by Bo-blog 2.0.3 sp1