js排序——sort()排序用法

js排序——sort()排序用法sort()方法用于对数组的元素进行排序,并返回数组。默认排序顺序是根据字符串Unicode码点。语法:array.sort(fun);参数fun可选。规定排序顺序。必须是函数。注:如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。如果想按照其他规则进行排序,就需要提供比较函数,该函数要比较两个值,然后返回…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

sort() 方法用于对数组的元素进行排序,并返回数组。默认排序顺序是根据字符串Unicode码点。

语法:array.sort(fun);参数fun可选。规定排序顺序。必须是函数。
注:如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。

如果想按照其他规则进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:
若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
若 a 等于b,则返回 0。
若 a 大于 b,则返回一个大于 0 的值。
简单点就是:比较函数两个参数a和b,返回a-b 升序,返回b-a 降序
//注:原数组发生改变

例:
1.不传参数,将不会按照数值大小排序,按照字符编码的顺序进行排序;

		var arr = ['General','Tom','Bob','John','Army'];
		var resArr = arr.sort();
		console.log(resArr);//输出   ["Army", "Bob", "General", "John", "Tom"]
		
		var arr2 = [30,10,111,35,1899,50,45];
		var resArr2 = arr2.sort();
		console.log(resArr2);//输出   [10, 111, 1899, 30, 35, 45, 50]

2.传入参数,实现升序,降序;

		var arr3 = [30,10,111,35,1899,50,45];
		arr3.sort(function(a,b){
			return a - b;
		})
		console.log(arr3);//输出  [10, 30, 35, 45, 50, 111, 1899]
		
		var arr4 = [30,10,111,35,1899,50,45];
		arr4.sort(function(a,b){
			return b - a;
		})
		console.log(arr4);//输出 [1899, 111, 50, 45, 35, 30, 10]

3.根据数组中的对象的某个属性值排序;

		var arr5 = [{id:10},{id:5},{id:6},{id:9},{id:2},{id:3}];
		arr5.sort(function(a,b){
			return a.id - b.id
		})
		console.log(arr5);
		//输出新的排序
		//		{id: 2}
		//		{id: 3}
		//		{id: 5}
		//		{id: 6}
		//		{id: 9}
		//		{id: 10}

4.根据数组中的对象的多个属性值排序,多条件排序;

		var arr6 = [{id:10,age:2},{id:5,age:4},{id:6,age:10},{id:9,age:6},{id:2,age:8},{id:10,age:9}];
		arr6.sort(function(a,b){
			if(a.id === b.id){//如果id相同,按照age的降序
				return b.age - a.age
			}else{
				return a.id - b.id
			}
		})
		console.log(arr6);
		//输出新的排序
		//		{id: 2, age: 8}
		//		{id: 5, age: 4}
		//		{id: 6, age: 10}
		//		{id: 9, age: 6}
		//		{id: 10, age: 9}
		//		{id: 10, age: 2}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

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


相关推荐

  • AC自动机(详解)

    AC自动机(详解)需要提前了解的知识 KMP 字典树例题 传送门 AC 自动机是 KMP 和字典树的结合体 如果说 KMP 用于单模式匹配 那么 AC 自动机是用于多模式匹配的 举个例子 KMP 适用于在一篇文章中找一句话 AC 自动机适合在一篇文章中寻找多句话 并不是简单的多用几次 KMP KMP 算法构建了一个查询表 nex 数组 我们可以按照相同的思路构建 nex 表 在 ac 自动机中成为失配数组 算法思路 先将所有的模式串建立字典树 建立 nex 数组 然后就开始匹配

    2025年10月3日
    5
  • 按键精灵q语言基础教学怎么看不了_按键精灵脚本是用什么语言写

    按键精灵q语言基础教学怎么看不了_按键精灵脚本是用什么语言写一、数据类型1.1数据类型可以表示一切的类型variant逻辑类型:boolean(true,false)数学类型: 整数:byte(0-255),integer(-32768-32767),lon

    2022年8月1日
    5
  • 单片机看门狗工作原理_51单片机看门狗

    单片机看门狗工作原理_51单片机看门狗/*此程序实现单片机”看门狗”WDT的功能*/#include”p18f458.h”unsignedlongi;/*系统初始化子程序*/voidinitial(){TRISD=0X00;/*D口设为输出*/}/*延时子程序*/voidDELAY(){for(i=19999;–i;)continue;}/*主程序*/main(){initial();/*初始化,设定看门狗的相关寄存器*/PO…

    2025年8月13日
    3
  • awstats mysql_Awstats 配置详解

    awstats mysql_Awstats 配置详解[root@testsrc]#wgethttp://prdownloads.sourceforge.net/awstats/awstats-6.95.tar.gz[root@testsrc]#tarzxvfawstats-6.95.tar.gz[root@testsrc]#mvawstats-6.95/usr/local/awstats[root@testsrc]#…

    2022年7月16日
    22
  • IntelliJ IDEA 社区版使用指南

    IDEA的专业版商用是需要付费的,不建议大家在工作中使用破解的软件。大家完全可以使用社区版,最棒的就是大家都可以贡献插件,本文从性能调优和安装插件两个方面来阐述社区版在使用过程中需要如何操作。 0.写在前…

    2022年3月13日
    811
  • 有向无环图表示算术表达式

    有向无环图表示算术表达式转载自 linkun 的博客题目描述 用有向无环图描述表达式 A B A B A 至少需要顶点的数目为几个 分析 先画出算术表达式 A B A B A 的二叉树表示 A B A B A 有重复的子表达式 A B 二叉树中可实现对子表达式的共享所以 相同的叶子节点可以共用 所以至少需要五个顶点 A B 各一个

    2025年9月23日
    3

发表回复

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

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