Js数组排序函数:sort()
原文链接:https://blog.csdn.net/qq_37936542/article/details/78979521
js原生的 sort() 排序函数使用起来很方便
语法:arrayObject.sort(fun) 数组对象.sort(排序函数)
如果调用该方法时没有使用参数,将按照字符编码的顺序进行排序。也可以提供一个比较函数
作为参数,实现大小的排序。
例一:对数值型元素的数组进行大小排序
- //定义一个比较函数
- //升序排序
- function NumAscSort(a,b)
- {
- return a - b;
- }
- //降序排序
- function NumDescSort(a,b)
- {
- return b - a;
- }
- //定义数组
- var arr = new Array( 10, 30, 15, 45, 8);
- //对数组进行升序排序
- arr.sort(NumAscSort);
- alert(arr);
- //对数组进行降序排序
- arr.sort(NumDescSort);
- alert(arr);
例二:对字符串类型元素数组进行排序
- //当调用sort函数没有给予参数时,默认根据字符编码的顺序进行排序
- var arr = ["Apple", "Banana", "Orange"];
- arr.sort();
- alert(arr);
例三:对象数组排序
- //定义compare函数,参数name是对象的某一个属性,比如age、salary
- //返回一个可以用来对包含该成员的对象数组进行排序的比较函数
- var compare = function(name){
- return function(o, p){
- var a, b;
- if (typeof o === "object" && typeof p === "object" && o && p) {
- a = o[name];
- b = p[name];
- if (a === b) {
- return 0;
- }
- if (typeof a === typeof b) {
- return a < b ? -1 : 1;
- }
- return typeof a < typeof b ? -1 : 1;
- }
- else {
- throw ("error");
- }
- }
- }
- //定义员工对象数组
- var emp=[];
- emp[0]={name:"xiaoming", age:32, salary:11000};
- emp[1]={name:"xiaohong", age:17, salary:23000};
- emp[2]={name:"dahuang", age:58, salary:9000};
- emp[3]={name:"dajiji", age:62, salary:15000};
- <span style="white-space:pre"> </span>
- <span style="white-space:pre"> </span>
- //排序
- emp.sort(compare("age"));
- <span style="white-space:pre"> </span>
- for(var i = 0;i<emp.length; i++){
- alert(emp[i].age)
- }
例四:根据多个属性对 ‘对象数组’ 进行排序
- //定义compare函数,name是对象的某一个属性,fun是一个比较函数
- var compare = function(name,fun){
- return function(o,p){
- var a,b;
- if(o && p && typeof o === 'object' && typeof p ==='object'){
- a = o[name];
- b = p[name];
- //当o[name] 和 p[name] 相等时,利用fun函数根据另一个属性来进行比较
- if(a === b){
- return typeof minor === 'function' ? fun(o,p):0;
- }
- if(typeof a === typeof b){
- return a < b ? -1:1;
- }
- return typeof a < typeof b ? -1 : 1;
- }else{
- thro("error");
- }
- }
- }
- //定义员工对象数组
- var emp=[];
- emp[0]={name:"xiaoming", age:32, salary:11000};
- emp[1]={name:"xiaohong", age:62, salary:23000};
- emp[2]={name:"dahuang", age:58, salary:9000};
- emp[3]={name:"dajiji", age:62, salary:15000};
- //先根据age排序,age相等时,根据工资排序
- emp.sort(compare('age',compare('salary')));
- <span style="white-space:pre"> </span>
- for(var i = 0;i<emp.length; i++){
- <span style="white-space:pre"> </span>alert(emp[i].name)
- }
文末福利:
福利一:前端,Java,产品经理,微信小程序,Python等10G资源合集大放送:https://www.jianshu.com/p/e8197d4d9880
福利二:微信小程序入门与实战全套详细视频教程
【领取方法】
关注 【编程微刊】微信公众号:
回复【小程序demo】一键领取130个微信小程序源码demo资源。
回复【领取资源】一键领取前端,Java,产品经理,微信小程序,Python等资源合集10G资源大放送。
原文作者:祈澈姑娘
原文链接:https://www.jianshu.com/u/05f416aefbe1
创作不易,转载请告知
90后前端妹子,爱编程,爱运营,爱折腾。
坚持总结工作中遇到的技术问题,坚持记录工作中所所思所见,欢迎大家一起探讨交流。
Js数组排序函数:sort()的更多相关文章
- Js数组排序函数sort()
JS实现多维数组和对象数组排序,用的其实就是原生sort()函数,语法为:arrayObject.sort(sortby)(sortby 可选.规定排序顺序.必须是函数.) 返回值为对数组的引用:请注 ...
- 深入探讨JS中的数组排序函数sort()和reverse()
最近在研究Javascript发现了其中一些比较灵异的事情.有点让人感到无语比如: alert(typeof( NaN == NaN));//结果为假. alert(typeof( NaN != Na ...
- JS中的数组排序函数sort()
JavaScript实现多维数组.对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序. sort() 方法用于对数组的元素进行排序.语法如下: arrayObject.sort ...
- PHP数组排序函数有哪些
PHP数组排序函数有哪些 一.总结 一句话总结:其实也就是是否保持索引,对键排序还是对值排序,除了sort,rsort.shuffle,usort外,都是保持索引的 是否保持索引 键排序 值排序 除了 ...
- js数组排序 reverse()和sort()方法的使用
WEB前端|js数组排序reverse()和sort()方法的使用,数组中已经存在两个可以直接用来重排序的方法:reverse()和sort(). reverse()方法会对反转数组项的顺序. var ...
- JS数组排序技巧汇总(冒泡、sort、快速、希尔等排序)
本文实例总结了JS数组排序技巧.分享给大家供大家参考,具体如下: 1.冒泡排序 var temp = 0; for (var i = 0; i < array.length; i++) { fo ...
- js数组之sort排序的用法
sort排序 转载自:https://blog.csdn.net/idomyway/article/details/80544509 js中用方法sort()为数组排序.sort()方法有一个可选参数 ...
- js 数组排序和算法排序
1.算法排序 a.插入排序 var arr = [23,34,3,4,23,44,333,444]; var arrShow = (function insertionSort(array){ if( ...
- js数组排序
在JS中,sort方法可用于数组的排序:先来看一个例子: var arr = [1, 2, 3, 5, 7, 78, 8, 89]; arr.sort(); console.log(arr); // ...
随机推荐
- Java学习笔记六 常用API对象二
1.基本数据类型对象包装类:见下图 public class Test { public static void main(String[] args){ Demo(); toStringDemo() ...
- Tuple<int, int> Dictionary<string, object>妙用
Tuple<int, int> Dictionary<string, object>妙用
- 前端项目中常用es6知识总结 -- Promise逃脱回调地狱
项目开发中一些常用的es6知识,主要是为以后分享小程序开发.node+koa项目开发以及vueSSR(vue服务端渲染)做个前置铺垫. 项目开发常用es6介绍 1.块级作用域 let const 2. ...
- SVN和Git代码管理小结
SVN和Git代码管理小结 之前,先用的是SVN,后来用了Git,最近又在用SVN. 关于代码管理,写几句. 由于自己参与的项目,人通常不超过10个人,版本不是很多,协作比较正常,感觉SVN ...
- 目标跟踪系列十一:Exploiting the Circulant Structure of Tracking-by-detection with Kernels代码思路
Tracking学习系列原创,转载标明出处: http://blog.csdn.net/ikerpeng/article/details/40144497 这篇文章非常赞啊!非常有必要将其好好的学习, ...
- OGRE之跳出漫长的编译等待
当你新建一个OGRE项目时是否发现那漫长的编译等待时间差点儿让你崩溃? 当你改动代码不断进行调试时是否由于那漫长的编译等待而让你烦恼? 假设是,那么请继续往下看,您将受益匪浅. ----------- ...
- 【MongoDB】The connection between two tables
In mongoDB, there are two general way to connect with two tables. Manual Connection and use DBRef 1. ...
- WebSocket兼容到低版本浏览器
就目前而言,WebSocket是最好的Web通信解决方案了.但是IE从10才开始兼容它,对于目前大量IE8存在的市场,原生的WebSocket显然不太实用,我们需要低版本兼容的解决方案.于是我模拟We ...
- jquery点击完一个按钮,并且触发另一个按钮
$a.click(function(){ $b.trigger('click'); });
- How to Rotate Tomcat catalina.out
If catalina.out becomes 2GB in size, tomcat crashes and fails to start without any error message. To ...