Heim  >  Artikel  >  Web-Frontend  >  如何写JS数组sort的比较函数_javascript技巧

如何写JS数组sort的比较函数_javascript技巧

WBOY
WBOYOriginal
2016-05-16 18:24:02913Durchsuche

譬如:
  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()   function f(a, b) {
if (a.toString().toLowerCase() return 1;
}
return -1;
}
  再譬如:要使数组的元素按先奇数后偶数的顺序排列,则若需a、b交换,仅当满足a是偶数且b是奇数条件即可,再按从小到大排序,仅当满足a、b均是奇数或偶数且a>b时即可。如下:

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

作者:JayChow
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn