Javascript数组(一)排序

一、简介
首先,我们来看一下JS中sort()和reverse()这两个函数的函数吧
reverse();这个函数是用来进行倒序,这个没有什么可说的,所谓倒序就是大的在前面,小的在后面。

  比如:

  var array1 = [0,1,5,10,15];

  array1.reverse();//结果为:15,10,5,1,0

sort([参数]);这个函数是用来对数组进行正序排列的,

var array1 = [0,1,5,10,15];

  array1.sort();//结果为:0,1,10,15,5

  注:sort() 方法可以接受一个 方法为参数 ,这个方法有两个参数。分别代表每次排序比较时的两个数组项。sort()排序时每次比较两个数组项都回执行这个参数,并把两个比较的数组项作为参数传递 给这个函数。当函数返回值为1的时候就交换两个数组项的顺序,否则就不交换。

有时候,我们大家在进行排序,尤其是数组排序。有可能,我们只是想去排列一组数据中的某一个数据的时候。如下面的这个例子。

  var data = [{name:"Tom",age:"28"},{name:"Cat",age:"29"}...];

我们只是想对这组数据中的name或age进行排序,这个时候大家就会发现,使用JS中的自代的函数sort()就不能解决这类型的问题。哪么此篇文章就是解决这个问题?

在简述一下此问题:假设有一个对象数组,我们想要根据某个对象属性对数组进行排序。而传递给数组sort()方法的比较函数要接收两个参数,这两个参数就是比较的值。可是,我们需要一种方式来指明按照哪个属性来排序。而sort()方法只能接受一个参数,这个时候,我们就可以利用一下JS自定义函数的特点来做。好吧,我们来看下。

看到上图,大家可能有点懵,这个函数定义看起来有点复杂,但实际上无非就是在这个函数的内部嵌套了另一函数,而且,这个内部的函数前面加了一个return操作符。在内部函数接收到pName参数后,使用方括号(可以看作数组取值)表示法来取得指定属性的值。那么,这里大家可能有点不明白,就是我们上篇文章在讲解的时候,明明sort在传递的参数只是一个不带参数的函数。这里我们可以回顾一下,JS函数的相关定义:要访问函数的指针而不执行函数的话,必须去掉函数后面的哪对圆括号。并且,ECMAscript中的函数名本身就是变量,所以函数也可以作为值来使用。也就是说,不仅可以像传递参数把一样把一个函数函数传递给另一个函数,而且可以将一个函数作为另一个函数的结果返回。

二、数字数组

1.默认ASCII字符顺寻

$(function () {
//Javascript数组排序
var nums = [8, 10, 2, 3, 1,100];
//默认ASII字符排序,升序
nums.sort();

//将默认ASCII字符排序反转
nums.reverse();
//遍历输出
for (var i = 0; i < nums.length; i++) {
$("#orderUl").append("<li>"+nums[i]+"</li>");;
}
});

<ul id="orderUl"></ul>

 ascii升序显示结果:   ascii降序显示:

2.数字数组升序和降序

$(function () {
//Javascript数组排序
var nums = [8, 10, 2, 3, 1,100];
//升序排列
nums.sort(function (a, b) {
return a > b ? 1 : -1;
});
//降序排列
nums.sort(function (a,b) {
return a < b ? 1 : -1;
});
//遍历输出
for (var i = 0; i < nums.length; i++) {
$("#orderUl").append("<li>"+nums[i]+"</li>");;
}
});

 升序排列:  降序排列:

三。混合数组

//混合数组
var nums = [‘a‘, 10, ‘w‘, ‘2‘,100, ‘b‘,‘array‘];
nums.sort();//按ascii字符顺序排序
//升序排序,顺序打乱
nums.sort(function (a, b) {
return a > b ? 1 : -1;
});
//遍历输出
for (var i = 0; i < nums.length; i++) {
$("#orderUl").append("<li>"+nums[i]+"</li>");;
}

 Asciii升序  按大小升序

   
三、json数组

//josn数组
var nums = [
{ id:3,name: ‘da‘, age: 25,remark:‘a‘ },
{ id: 1, name: ‘alla‘, age: 21, remark: ‘d‘ },
{ id: 4, name: ‘cs‘, age: 22, remark: ‘b‘ },
{ id: 2, name: ‘bs‘, age: 29, remark: ‘c‘ },
];
nums.sort();//默认根据第一个字符串列按ascii字符顺序排序
function orderBy(age) {//排序函数升序,调用时指定排序列
return function (object1, object2) {
var val1 = object1[age];
var val2 = object2[age];
if (val1 < val2) return -1;
else if (val1 > val2) return 1;
else return 0;
}
}
nums.sort(orderBy(‘age‘));
//遍历输出
for (var i = 0; i < nums.length; i++) {
$("#orderUl").append("<li>" + nums[i].id + "--" + nums[i].name + "--" + nums[i].age + "--" + nums[i].remark + "</li>");;
}

 默认排序  指定age排序  指定remark排序



默认根据json对象第一个字符串列按ascii排序 按age数字列升序 按reamark字符列排序

原文地址:https://www.cnblogs.com/tianma3798/p/10580009.html

时间: 2024-07-29 08:52:06

Javascript数组(一)排序的相关文章

javascript数组对象排序

javascript数组对象排序 JavaScript数组内置排序函数 javascript内置的sort函数是多种排序算法的集合 JavaScript实现多维数组.对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序. sort() 方法用于对数组的元素进行排序.语法如下: ArrayObject.sort(order); 测试A: var mm=[1,4,0,6,3,1,2]; mm.sort(); alert(mm);//0 1 1 2 3 4 6 返回值为对数组的引

Javascript 数组自定义排序,并获取排序后的保存原索引的同位数组(堆排序实现)

比如数组A: [ 0: 5, 1: 2, 2: 4, 3: 3, 4: 1 ] 排序后的结果为:[1, 2, 3, 4, 5],但是有时候会有需求想要保留排序前的位置到一个同位数组里,如前例则为:[4, 1, 3, 2, 0],因此就利用堆排序写了一个单独的数组排序过程加以实现. 代码如下: function arrayKeys(arr) { var i = 0, len = arr.length, keys = []; while (i < len) { keys.push(i++); } r

javascript数组原生排序

var month = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October ', 'November', 'December']; var list = [ { name: '张三', age: 243, sex: 1, price: "¥3.6", month: "August", ip: "192.168.1.1

javascript 数组Array排序

var numberAry = [9,9,10,8,7,80,33,55,22]; numberAry.sort(); /*输出:10,22,33,55,7,8,80,9,9 上面的代码没有按照数值的大小对数字进行排序,只是按照首字母进行了排序,所以需要定义一个排序函数*/ 1.定义一个排序函数(正序) function sortNumber(a,b){ return a - b; } numberAry.sort(sortNumber); //输出:7,8,9,9,10,22,33,55,80

JavaScript 使用 sort() 方法从数值上对数组进行排序

使用 sort() 方法从数值上对数组进行排序. <html> <body> <script type="text/javascript"> function sortNumber(a, b) { return a - b } var arr = new Array(6) arr[0] = "10" arr[1] = "5" arr[2] = "40" arr[3] = "25&q

JavaScript对数组进行排序小程序

JavaScript数组的sort()函数是按字符串大小排序,不能正确对一组数字进行排序下面的小程序通过一个自编的函数实现了对一组数字进行排序的功能. <script> function mysort(a){ var n=a.length; var newa=[]; var temp; for(var i=0;i<n;i++) { for(var j=i;j<n;j++) { if(a[i]>a[j]) { temp=a[i]; a[i]=a[j]; a[j]=temp; }

Javascript数组系列四之数组的转换与排序Sort方法

今天我们继续来介绍 Javascirpt 数组中的方法,也是数组系列的第四篇文章,因为数组的方法众多,每篇文章我们都对数组的每个方法都有比较细致的描述,只要你能够从中成长一点点,那我们的目的就达到了,学习是一个持续的,渐进的过程.每天进步一点点,最终会有大成就. 直接进入主题 数组的转换 我们在项目的开发过程中,数据类型之间的转换有着非常重要的作用,而数组转换成其他数据类型是我们常见的一种. toString 该方法是对数组转换成字符串,数组的每一个元素都会调用 「toString」方法 ,返回

javascript实现数组随机排序和去重

let arr = ['g', 'b', 'c', 'd', 'e', 'a', 'g', 'b', 'c']; // 数组随机排序(原数组被修改)Array.prototype.randomSort = function () { const len = this.length; for (let i = len - 1; i > 1; i--) { let n = Math.floor(Math.random() * i); let lastone = this[i]; this[i] =

给object数组进行排序(排序条件是每个元素对象的属性个数)

从汤姆大叔的博客里看到了6个基础题目:本篇是第3题 - 给object数组进行排序(排序条件是每个元素对象的属性个数) 解题关键: 1.Array.sort的用法 2.object的属性数量的统计 解点1:Array.sort的用法 Array.sort可以为数组指定一个排序规则,一般用如下格式进行指定,代码如下: var arr = [10,6,0,4]; console.log( arr.sort() ); //按字符排序 0,10,4,6 console.log( arr.sort( fu