js中array的sort()方法使用介绍
更新时间:2014年02月20日 16:38:19 作者:
默认的sort方法并不是按照整形数据来排序,而是用的字符串匹配方式,下面有个不错的示例,大家可以参考下
或许你一直在用javascript中的array的sort.
或许你一直相信它会给你正确的结果。
至少我曾经也是这样认为的,直到有一天,我看到了如下的代码 :
[5,10,1].sort();
或许结果有点出人意料。结果如下:
[1,10,5]
仔细深究之后,发现原来默认的sort方法并不是按照整形数据来排序,而是用的字符串匹配方式。
换言之就是10 中的这个 1 导致了上面代码的错误。
当然,解决方法有很多,可以给sort方法中传入回调函数。
[5,10,1].sort(function(x,y){
if(x>y) {return 1;
}else{
return -1
}
}
);
这样就能得到你预期的结果了。
偶然发现,以记录之,防止忘记。
或许你一直相信它会给你正确的结果。
至少我曾经也是这样认为的,直到有一天,我看到了如下的代码 :
复制代码 代码如下:
[5,10,1].sort();
或许结果有点出人意料。结果如下:
复制代码 代码如下:
[1,10,5]
仔细深究之后,发现原来默认的sort方法并不是按照整形数据来排序,而是用的字符串匹配方式。
换言之就是10 中的这个 1 导致了上面代码的错误。
当然,解决方法有很多,可以给sort方法中传入回调函数。
复制代码 代码如下:
[5,10,1].sort(function(x,y){
if(x>y) {return 1;
}else{
return -1
}
}
);
这样就能得到你预期的结果了。
偶然发现,以记录之,防止忘记。
相关文章
JavaScript中判断函数是new还是()调用的区别说明
具名函数的各种调用方式 在之前篇幅中已经介绍过了。这篇看看如何判断一个函数是被new调用的,还是被其它方式调用的。2011-04-04axios如何利用promise无痛刷新token的实现方法
这篇文章主要介绍了axios如何利用promise无痛刷新token的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-08-08JSCode all of Brower 全局屏蔽网页右键功能 具体实现
JSCode all of Brower 全局屏蔽网页右键功能 具体实现,需要的朋友可以参考一下2013-06-06
最新评论