如何写JS数组sort的比较函数

时间:2010-07-02 12:12:00 

我们知道,数组的sort方法可以对数组元素进行排序,默认是按ASCII字母表顺序排序。如果要根据其他的顺序排序就需要为sort方法提供一个比较函数作为参数。这里讲的就是如何写这个比较函数。

譬如:

  var a=[1,5,3,7]; 
  a.sort(function(a, b) { return b-a});//从大到小排列 


  那如果复杂点的顺序应该如何写这个比较函数呢。

对于比较函数function f(a,b){...} ,若返回正数,则说明a和b需要交换,否则不交换。所以我们可以通通根据下面的格式去写比较函数:

 

function f(a, b) { 
if (...) { 
return 1; 

return -1; 

然后,我们要做的就是写出if里面的条件,这个条件就是返回a、b需要交换的条件。譬如:对var a=["a","A","B","b"];进行不分大小写并从大到小排序,仅当a.toString().toLowerCase() < b.toString().toLowerCase()时,交换a、b,所以用此填充if条件即可。比较函数就是:

  function f(a, b) { 
if (a.toString().toLowerCase() < b.toString().toLowerCase()) { 
return 1; 

return -1; 


  再譬如:要使数组的元素按先奇数后偶数的顺序排列,则若需a、b交换,仅当满足a是偶数且b是奇数条件即可,再按从小到大排序,仅当满足a、b均是奇数或偶数且a>b时即可。如下:


标签:函数,排序,sort
0
投稿

猜你喜欢

  • 教你在MySQL 5.0以上版本中配置主从库

    2009-01-04 13:17:00
  • asp如何正确理解和使用Command、Connection和 Recordset三个对象?

    2010-06-28 18:23:00
  • 有关于IE8 Beta 1两个提醒

    2008-05-15 12:32:00
  • 一个表单焦点效果函数

    2008-01-19 10:59:00
  • thinkphp5实用入门进阶知识点和各种常用功能代码汇总

    2023-05-25 02:48:34
  • 对SQL Server数据库进行优化的经验总结

    2010-07-26 14:52:00
  • 浅析Banner构成与创意设计

    2009-11-28 16:25:00
  • asp常用数据库连接方法和技巧

    2010-05-27 12:28:00
  • MSSQL中部分字段重复数据的删除方法

    2008-12-29 13:59:00
  • PHP和JS之间的数据交互并处理

    2023-05-25 00:57:08
  • 关于Ajax在浏览器中产生前进后退的实现方法

    2010-01-29 13:01:00
  • 关于字体的一些思考

    2008-03-03 12:53:00
  • 10个糟糕的IE Bug及其修复

    2010-05-13 16:26:00
  • MySQL 数据(字段)类型

    2011-09-10 16:15:56
  • CSS控制鼠标样式变换方法

    2007-11-17 07:58:00
  • 如何在服务器端调用winzip命令行对文件压缩和解压

    2008-01-26 20:44:00
  • Mysql入门系列:MySQL数据目录的位置

    2008-11-24 12:59:00
  • margin双倍边距问题:ie和firefox显示

    2008-09-07 15:05:00
  • MYSQL启用日志和查看日志

    2010-12-03 16:24:00
  • asp检测表单输入EMAIL合法性的函数

    2007-10-16 13:39:00
  • asp之家 网络编程 m.aspxhome.com