js sort() 排序用法(转载)
原文:https://blog.csdn.net/m0_37885651/article/details/80016718
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}
改成参数方法
arr5.sort(sortBy(attr,rev));
//attr:根据该属性排序;rev:升序1或降序-1,不填则默认为1
sortBy(attr,rev){
if( rev==undefined ){ rev=1 }else{ (rev)?1:-1; }
retrun function (a,b){
a=a[attr];
b=b[attr];
if(a<b){ return rev*-1}
if(a>b){ return rev* 1 }
retrun 0;
}
}
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}
5、sort还时常用到拷贝!因为sort会改变原始数据的顺序。
var dataTemp= data.concat([]);
6、用sort排序,求最大值。
        function getMax(arr) {
            if (arr != null && (arr instanceof Array) && arr.length > ) {
                let arr2 = arr.concat([]);
                arr2.sort(function (a, b) { return a - b })
                let max = arr2[arr2.length - ];
                console.log('max', max);
                return max;
            }
            return null;
        }
        function getMax2(arr, name) {
            if (arr != null && (arr instanceof Array) && arr.length > ) {
                let arr2 = arr.concat([]);
                arr2.sort(function (a, b) { return a[name] - b[name] })
                let max = arr2[arr2.length - ][name];
                console.log('max', max);
                return max;
            }
            return null;
        }
相关资料:
https://www.cnblogs.com/saifei/p/9043821.html
http://www.w3school.com.cn/js/jsref_sort.asp
js sort() 排序用法(转载)的更多相关文章
- js排序——sort()排序用法
		sort() 方法用于对数组的元素进行排序,并返回数组.默认排序顺序是根据字符串Unicode码点. 语法:array.sort(fun):参数fun可选.规定排序顺序.必须是函数.注:如果调用该方法 ... 
- C/C++-中的sort排序用法
		转载于:http://www.cnblogs.com/luorende/p/6121906.htmlSTL中就自带了排序函数sortsort 对给定区间所有元素进行排序 要使用此函数只需用#inclu ... 
- C++ 中的sort排序用法
		STL中就自带了排序函数sortsort 对给定区间所有元素进行排序 要使用此函数只需用#include <algorithm> sort即可使用,语法描述为:sort(begin,end ... 
- js sort() 排序的问题
		默认并非按照大小排序,而是根据Assic来排序的,但接受一个排序函数.所以正确的使用姿势应该是这样的: var arr = [0,1,5,10,15]; function sequence(a,b){ ... 
- sort排序用法
		Python] sorted函数 我们需要对List.Dict进行排序,Python提供了两个方法对给定的List L进行排序,方法1.用List的成员函数sort进行排序,在本地进行排序,不返回副本 ... 
- 关于js sort排序方法
		sort() 方法用于对数组的元素进行排序. 语法:arrayObject.sort(sortby):参数sortby可选.规定排序顺序.必须是函数. 当方法不带参数的时候,将按照字符编码顺序进行排序 ... 
- C++ STL 之 deque容器 打分案例(内含sort排序用法)
		#include <iostream> #include <vector> #include <time.h> #include <deque> #in ... 
- List.Sort 排序用法收集
		使用Lambda表达式,实现代码如下: private static void SortByLambda() { List<Article> list ... 
- js数组之sort排序的用法
		sort排序 转载自:https://blog.csdn.net/idomyway/article/details/80544509 js中用方法sort()为数组排序.sort()方法有一个可选参数 ... 
随机推荐
- python 把带小数的浮点型字符串转换为整数的解决方案
			以下内容在python中完全可以接受: 将整数的字符串表示形式传递给 int 将float的字符串表示形式传递给 float 但是,如果你将float型的字符串传递给int将会得到错误. >&g ... 
- Qt QJson解析json数据
			Qt QJson解析json数据 //加载根目录文件 void TeslaManageData::loadRootFolderFiles() { QNetworkAccessManager *mana ... 
- Spring cloud微服务安全实战-7-1章节概述
			前面的章节都是围绕这微服务的安全在讲一些东西,包括微服务本身api的安全.网关的安全.怎么去做安全中心,包括认证服务器,权限的服务.权限的设计,怎么来实现SSO.然后sentinel来实现统一的熔断, ... 
- [Bayes] Concept Search and LDA
			重要的是通过实践更深入地了解贝叶斯思想,先浅浅地了解下LDA. 相关数学知识 LDA-math-MCMC 和 Gibbs Sampling LDA-math - 认识 Beta/Dirichlet 分 ... 
- knuth洗牌算法
			首先来思考一个问题: 设计一个公平的洗牌算法 1. 看问题,洗牌,显然是一个随机算法了.随机算法还不简单?随机呗.把所有牌放到一个数组中,每次取两张牌交换位置,随机 k 次即可. 如果你的答案是这样, ... 
- [LeetCode] 210. Course Schedule II 课程安排II
			There are a total of n courses you have to take, labeled from 0 to n - 1. Some courses may have prer ... 
- sonar:默认的扫描规则
			https://blog.csdn.net/liumiaocn/article/details/83550309 https://note.youdao.com/ynoteshare1/index.h ... 
- 对get post等http请求方式的理解
			本文是关于get,post等几种请求方式的资料搜集和学习,HTTP,HTTP2协议的涉及点,然后提到了socket协议,RPC 先是和朋友的一些交流对话,问着问着就到了我的知识盲区.需要恶补一下这方面 ... 
- Hystrix学习笔记
			服务降级: DashBoard: 例中的8001为要监控的地址: 
- 【剑指offer】面试题 18. 删除链表的节点
			面试题 18. 删除链表的节点 
