JS_高阶函数(sort)

 //javaScript sort()排序算法
//sort()方法默认把所有的元素转换成String再排序,字符串是根据ASCII进行排序的,所以会出现“10”排在“2”前面,或是小写字母“a”排在大写“B”的后面等情况。、 //可以通过接收一个比较函数来实现自定义的排序。
/**/
var arr=[10,20,1,2];
arr.sort(function(x,y){
if(x<y){
return -1;
}
if(x>y){
return 1;
}
return 0;
});
console.log(arr);//[1, 2, 10, 20] /**/
var arr=[10,20,1,2];
arr.sort(function(x,y){
if(x>y){
return -1;
}
if(x<y){
return 1;
}
return 0;
});
console.log(arr);//[20, 10, 2, 1] /**/
//对字符串按字母顺序进行排序。实际上就是把字符串都变成大写(或者是都变成小写),再比较。
var arr = ['Google', 'apple', 'Microsoft'];
var a=arr.sort(function(s1,s2){
x1=s1.toUpperCase();
x2=s2.toUpperCase();
if(x1<x2){
return -1;
}
if(x1>x2){
return 1;
}
return 0;
});
console.log(a);//["apple", "Google", "Microsoft"] //要注意的是:sort()方法会直接对Array进行修改,它返回的结果仍是当前Array。
console.log(arr);// ["apple", "Google", "Microsoft"]
上一篇:-webkit-appearance: none;


下一篇:查找素数(0~1000)的算法(Java代码)