+ -
当前位置:首页 → 问答吧 → Javascript数组sort方法的分析

Javascript数组sort方法的分析

时间:2008-10-15

来源:互联网

javascript 中 Array.sort()方法是用来对数组项进行排序的 ,默认情况下是进行升序排列,实例代码如下:  
var arrA = [6,2,4,3,5,1];
arrA.sort();
document.writeln(arrA);
  //结果是:1,2,3,4,5,6
  sort() 方法可以接受一个 方法为参数 ,这个方法有两个参数。分别代表每次排序比较时的两个数组项。sort()排序时每次比较两个数组项都回执行这个参数,并把两个比较的数组项作为参数传递给这个函数。当函数返回值为1的时候就交换两个数组项的顺序,否则就不交换。
  实例如下:
 var arrA = [6,2,4,3,5,1];
 /**//*arrA.sort();
 document.writeln(arrA);
 */
 function desc(x,y)
 ...{
   if (x > y)  
     return -1;
   if (x < y)      
     return 1;
 }
 function asc(x,y)
 ...{
   if (x > y)  
     return 1;
   if (x < y)      
     return -1;
 }
 arrA.sort(desc);  // sort by desc
 document.writeln(arrA);
 document.writeln("
");
  arrA.sort(asc);  //sort by asc
 document.writeln(arrA);
  //输出结果:
  6,5,4,3,2,1
  1,2,3,4,5,6
  另外,可以直接把一个无名函数直接放到sort()方法的调用中。如下的例子是将奇数排在前面,偶数排在后面,例子如下:
   var arrA = [6,2,4,3,5,1];
   arrA.sort( function(x, y) ...{
     if (x % 2 ==0)  
       return 11;
     if (x % 2 !=0)     
       return -1; 
     }
   );
   document.writeln(arrA);
  //输出:1,5,3,4,6,2

作者: 居士   发布时间: 2008-10-15

热门下载

更多