数组排序 sort() 方法 (映射对含有大小写的字符串进行排序)

编程入门 行业动态 更新时间:2024-10-08 02:18:26

<a href=https://www.elefans.com/category/jswz/34/1771288.html style=数组排序 sort() 方法 (映射对含有大小写的字符串进行排序)"/>

数组排序 sort() 方法 (映射对含有大小写的字符串进行排序)

结论先行:

sort() 方法:用于对数组元素进行排序,默认升序。如果指明了参数,那数组会按照比较函数的返回值进行排序。  

sort() 方法比较两个值时,将值发送给比较函数,根据返回的(负、零、正)值对值进行排序。举例,a 和 b 两个将要被比较的元素:

如果 a-b 小于 0 ,那么 a 会被排列到 b 之前。

如果 a-b 等于 0 , a 和 b 的相对位置不变。

如果 a-b 大于 0 , b 会被排列到 a 之前。

简单的理解,就是: a-b升序      b-a 降序 

具体解析:

1、概念

sort() 是 JavaScript 中数组对象的一个方法,用于对数组元素进行排序。

它会原地修改数组,将数组元素重新排列,并返回排序后的数组。

默认情况下,sort() 方法将数组元素视为字符串并按照 Unicode 码点进行排序。

排序顺序可以是按字母或数字,也可以是升序(向上)或降序(向下)。默认情况下,sort() 方法将按字母和升序将值作为字符串进行排序。

2、语法

array.sort(compareFunction)

参数说明:

  • compareFunction(可选):用于指定排序顺序的比较函数。

如果不提供 compareFunction 参数,sort() 方法将按照字符串 Unicode 码点的顺序对数组元素进行排序。

3、参数详解

该函数应返回负值、零值或正值,具体取决于参数,例如:

function(a, b){ return a-b }

sort() 方法比较两个值时,将值发送给比较函数,根据返回的(负、零、正)值对值进行排序。

举例,a和b 两个将要被比较的元素:

如果 a-b 小于 0 ,那么 a 会被排列到 b 之前。

如果 a-b 等于 0 , a 和 b 的相对位置不变。

如果 a-b 大于 0 , b 会被排列到 a 之前。

简单的理解,就是: a-b升序         b-a 降序 

const arr = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5];
arr.sort((a, b) => a - b);
console.log(arr); // [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]

在这个示例中,我们提供了一个比较函数 (a, b) => a - b,它表示按照数字大小进行升序排序。因此,最终数组被排序成了 [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]

需要注意的是,sort() 方法会直接修改原始数组,并返回排序后的数组。如果需要保留原始数组,可以在排序前先创建一个副本进行操作。

4、应用

①  非数字排序:字母顺序

字符串排序,可以直接使用 sort() 方法

var fruits = ["Banana", "Orange", "Apple", "Mango", "Blueberries"];
fruits.sort(); // ["Apple", "Banana", "Blueberries", "Mango", "Orange"]
var arr = ['h','a','k','c','e'];
arr.sort();
console.log(arr)  // ["a", "c", "e", "h", "k"]

按字母顺序对数组进行排序,然后反转排序项的顺序(降序):

var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.sort();
fruits.reverse();
console.log(fruits) //  ["Orange", "Mango", "Banana", "Apple"]
② 数字 

默认会将其作为字符串进行排序

var arr = [12, 22, 66, 3]
arr.sort()
console.log(arr) // [12, 22, 3, 66]
③ 按 升序 对数组中的数字进行排序:a-b
var points = [4, 10, 1, 5, 25, 10];
points.sort(function(a, b){ return a-b });console.log(points) // [1, 4, 5, 10, 10, 25]
④ 按 降序 对数组中的数字进行排序:b-a
var points = [4, 10, 1, 5, 25, 10];
points.sort(function(a, b){ return b-a });console.log(points) // [25, 10, 10, 5, 4, 1]
⑤ 获取数组中的最小值:
var points = [40, 100, 1, 5, 25, 10];
points.sort(function(a, b){ return a-b });    // 按升序对数组中的数字进行排序// 数组中的第一项 (points[0]) 现在是最小值
⑥ 获取数组中的最大值:
var points = [40, 100, 1, 5, 25, 10];
points.sort(function(a, b){ return b-a });    // 按降序对数组中的数字进行排序// 数组中的第一项 (points[0]) 现在是最大值
⑦ 根据对象的某个属性进行排序:
var arr = [{ name: 'A', age: 21 },{ name: 'B', age: 37 },{ name: 'C', age: 18 },{ name: 'D', age: -12 },{ name: 'E', age: 15 },{ name: 'F', age: 19 }];// 依据age排序
arr.sort(function(a, b) {return a.age - b.age
});
console.log(arr); // 0: {name: "D", age: -12}// 1: {name: "E", age: 15}// 2: {name: "C", age: 18}// 3: {name: "F", age: 19}// 4: {name: "A", age: 21}// 5: {name: "B", age: 37}
// 依据name排序
arr.sort(function(a, b) {const nameA = a.name;const nameB = b.name;if(nameA < nameB) {return -1;}if(nameA > nameB) {return 1;}return 0;
});
console.log(arr); // 0: { name: 'A', age: 21 }// 1: { name: 'B', age: 37 }// 2: { name: 'C', age: 18 }// 3: { name: 'D', age: -12 }// 4: { name: 'E', age: 15 }// 5: { name: 'F', age: 19 }
⑧ 非ASCII字符排序(如类似 e, é, è, a, ä 等字符的字符串)

一些非英语的字符串,需要使用 String.localeCompare

var a = ['réservé', 'premier', 'cliché', 'communiqué', 'café', 'adieu'];
a.sort(function (a, b) {return a.localeCompare(b);
});console.log(a); // ["adieu", "café", "cliché", "communiqué", "premier", "réservé"]
⑨ 使用映射对含有大小写的字符串进行排序

方法一: 

// 需要被排序的数组
var list = ['Delta', 'alpha', 'CHARLIE', 'bravo'];// 对需要排序的数字和位置的临时存储
var mapped = list.map((item, index) => { return { index, value: item.toLowerCase() }
})console.log(mapped) // 0: {index: 0, value: "delta"}// 1: {index: 1, value: "alpha"}// 2: {index: 2, value: "charlie"}// 3: 3: {index: 3, value: "bravo"}// 按照多个值排序数组
mapped.sort((a, b) => {return +(a.value > b.value) || +(a.value === b.value) - 1;
});console.log(mapped) // 0: {index: 1, value: "alpha"}// 1: {index: 3, value: "bravo"}// 2: {index: 2, value: "charlie"}// 3: {index: 0, value: "delta"}// 根据索引得到排序的结果
var result = mapped.map((el) => {return list[el.index];
});console.log(result); // ["alpha", "bravo", "CHARLIE", "Delta"]

方法二:

// 需要被排序的数组
var list = ["Delta", "alpha", "CHARLIE", "bravo"];
let newObj = {};
list.forEach((item, index) => {newObj[(item.toLocaleLowerCase())] = item
});
console.log(newObj) 
// { alpha: "alpha", bravo: "bravo", charlie: "CHARLIE", delta: "Delta" }let arr = Object.keys(newObj);
arr.sort((a, b) => {if (a < b) {return -1;} else if (a > b) {return 1;} else {return 0;}
});
console.log(arr); // ["alpha", "bravo", "charlie", "delta"]let res = arr.map(item => item = newObj[item])
console.log(res) //  ["alpha", "bravo", "CHARLIE", "Delta"]

更多推荐

数组排序 sort() 方法 (映射对含有大小写的字符串进行排序)

本文发布于:2024-02-26 04:28:50,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1701351.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:数组   大小写   字符串   方法   sort

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!