sort排序「建议收藏」

sort排序「建议收藏」Array对象一个方法:sort(),它是用来排序的。用法如下:vararr=[1,65,6,7,12,0];vars=arr.sort();console.log(s);//[0,1,12,6

大家好,又见面了,我是你们的朋友全栈君。

Array对象一个方法:sort(),它是用来排序的。用法如下:

var arr=[1,65,6,7,12,0];
var s=arr.sort();
console.log(s);   //[0,1,12,6,65,7]

 一般这样直接排出来的东西都不是我和我的小伙伴想要的。数组对象直接调用sort()方法,sort()方法把它每一个数组元素都转换为字符串,然后再按照字符编码进行排列

但是,该方法接收一个参数,而且,该参数为一个函数,然后,该函数会接收两个参数分别代表排序比较时的两个元素,并返回一个数值,sort()方法会根据该数值进行排序:

如果函数返回值大于 0 ,就将两个元素位置进行交换,反之则不交换

var arr=[1,65,6,7,12,0];
var s=arr.sort(function(a,b){
  return a-b
});
console.log(s);  //[0,1,5,7,12,65]

这次已经能够对number类型正确排序了。 

其实主要要说的一点是,sort()方法,排序时是这样的:它先把数组的元素两两相比,把小的放前面大的放后面,重复此操作,直到把所有元素都比一轮后才结束,每次比较都生成一个新的数组。如果比较[6,2,4,3,5,1]这个数组,

如下图:

sort排序「建议收藏」

规律是:第一轮(比较数组总数-1)次.以后每轮比较次数再-1,一直比较到(array.length-1)轮。

所以我们知道了sort有参数(函数)时排序原理。

那么,其实它是可以对二维数组及数组里的对象进行排序的。

代码说明一切:

;(function(){

  var a=[[6,4,0],[2,4,3],[5,4,1]];

  console.log(a.sort(
	function(x,y){
	     return x[0] - y[0];
	}
  ))  
})();//[[2,4,3],[5,4,1],[6,4,0]]

  

这是对二维数组里的第一个数组元素进去排序的。返回结果是把整个数组都有移动。而不是单纯的移动第一个元素。

再来看下面一组,数组里是对象的如何排序。命名什么的咱就不care了。

;(function(){
	var b=[
		{
			val:5,
			b:6
		},
		{
			val:4,
			b:8
		},
		{
			val:1,
			b:2
		}
	]
	var sortFun=function(name){
		return function(x,y){
			return x[name]-y[name];
		}
	}
	console.log(b.sort(sortFun('val')));

})();//[{b:2,val:1},{b:8,val:4},{b:6,val:5}]

神奇的是返回结果把把对象里面的元素也排了一遍,但是其实还是按照val的值进行排序的。也是对象整个都移了一下。

如果想要按照中文来排序。其实就是按照拼音的先后顺序来排的。可以用这一个不知名法宝,当当当当当:localeCompare()  该方法在w3school上是这样描述的:

localeCompare() 方法提供的比较字符串的方法,考虑了默认的本地排序规则。ECMAscript 标准并没有规定如何进行本地特定的比较操作,它只规定该函数采用底层操作系统提供的排序规则。

具体是什么意思,我理解为是按系统设置的某些来判定是按什么排序,如中文,它的用法如下

stringObject.localeCompare(target)

 用stringObject与target进行比较。如果 stringObject 小于 target(即拼音排列在前),则 localeCompare() 返回小于 0 的数。如果 stringObject 大于 target,则该方法返回大于 0 的数。如果两个字符串相等,或根据本地排序规则没有区别,该方法返回 0。这也sor()返回值是一个意思。

;(function(){
	var str="北京的天好蓝哈真的哦";
	str=str.split('');
	console.log(str.sort(function(a,b){
		return a.localeCompare(b);
	}))
})();     //["北", "的", "的", "哈", "好", "京", "蓝", "哦", "天", "真"] 

 把字符串也进行了排序。具体是不是按拼音,我真的不记得拼音是怎么个顺序了。0.0.. 

 


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155314.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • media type的类型汇总

    media type的类型汇总用的比较多的是screen和print:区分打印和屏幕显示(Android,iPhone都不是手持设备handheld,都是screen设备)转载于:https://www.cnblogs.com/hulaoxi/p/6140054.html

    2022年5月25日
    81
  • springboot Jpa多数据源(不同库)配置

    springboot Jpa多数据源(不同库)配置一、前言springboot版本不同对多数据源配置代码有一定影响,部分方法和配置略有不同。本文采用的springboot版本为2.3.12,数据源为mysql和postgresql二、配置实战2.1基础pom<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</ar

    2022年10月20日
    0
  • Android浏览器的插件渲染模式简介

    Android浏览器的插件渲染模式简介简单介绍了Android浏览器的插件渲染模式(bitmap模式和surface模式)

    2022年5月14日
    42
  • 应届毕业生java面试准备_Java应届生面试

    应届毕业生java面试准备_Java应届生面试应届没工作经验的可以看看。背景介绍:非名校,软件工程专业,无相关工作经验,实际编程只有在学校学习时。刚刚毕业,找工作中。大家都知道,开发这一行没有工作经验相当的吃亏,如果没有丰富的知识,对知识良好的理解,与优秀的自学能力,很难找到工作。经过近一个月的面试,总结一些信息。面试过程…

    2022年9月23日
    0
  • 【深度思考】郑州java培训机构排名

    【深度思考】郑州java培训机构排名前言分布式,是程序员必备技能之一,在面试过程中属于必备类的,在工作中更是会经常用到。而Kafka是一个分布式的基于发布订阅的消息队列,目前它的魅力是无穷的,对于Kafka的奥秘,还需要我们细细去探寻。要谈对Kafka有多熟悉,我相信还是阿里的大佬们最有发言权,所以今天分享的内容,就是Alibaba内部供应的“限量笔记”,关于Kafka的精髓全部写在这里面了,不得不感叹:不愧是Alibaba的技术官啊,真的服了!一、背景我们日常在电商网站购物时经常会遇到一些高并发的场景,例如电商App上经常出现的

    2022年10月3日
    0
  • Ignatius and the Princess III HDU – 1028 -生成函数or完全背包计数

    Ignatius and the Princess III HDU – 1028 -生成函数or完全背包计数

    2021年6月21日
    128

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号