ES6引入了许多新的特性,使得数组排序变得更加方便快捷。本文将从多个方面详细阐述ES6数组排序,让读者能够对此方面有更深刻的认识。
一、ES6数组排序sort
ES6数组中提供了sort方法用于排序,该方法会改变原数组。
let arr = [3, 2, 1, 4];
arr.sort();
console.log(arr); // [1, 2, 3, 4]
sort方法默认会按照字符串的Unicode值进行排序。如果要按照数字大小进行排序,则需要传入比较函数。
let arr = [3, 2, 1, 4];
arr.sort(function(a, b) {
return a - b;
});
console.log(arr); // [1, 2, 3, 4]
这里传入的比较函数会返回一个小于0的值、等于0的值或大于0的值。当返回小于0的值时,表示a应该排在b的前面;当返回等于0的值时,表示a和b相等;当返回大于0的值时,表示a应该排在b的后面。
二、数组排序方法
除了sort方法外,数组还提供了许多其他排序方法。
1. reverse
reverse方法用于反转数组,它会改变原数组。
let arr = [1, 2, 3, 4];
arr.reverse();
console.log(arr); // [4, 3, 2, 1]
2. join
join方法用于将数组转换为字符串,它不会改变原数组。
let arr = [1, 2, 3, 4];
let str = arr.join('-');
console.log(str); // "1-2-3-4"
console.log(arr); // [1, 2, 3, 4]
3. slice
slice方法用于返回原数组的一个子数组,它不会改变原数组。
let arr = [1, 2, 3, 4];
let newArr = arr.slice(1, 3);
console.log(newArr); // [2, 3]
console.log(arr); // [1, 2, 3, 4]
三、ES6数组排序的方法
除了sort方法外,ES6还提供了其他排序方法。
1. entries、keys、values
entries、keys、values方法返回一个迭代器对象,可以用于遍历数组的键值对、键、值。
let arr = [1, 2, 3, 4];
for(let [index, value] of arr.entries()) {
console.log(index, value);
}
// 输出:
// 0 1
// 1 2
// 2 3
// 3 4
2. copyWithin
copyWithin方法用于将数组中的一部分复制到另一部分,它会改变原数组。
let arr = [1, 2, 3, 4];
arr.copyWithin(2, 0, 2);
console.log(arr); // [1, 2, 1, 2]
这里将数组中的前两个元素复制到了数组中的第二个位置和第三个位置。
四、ES6数组排序
在ES6中,我们还可以使用箭头函数和展开运算符进行数组排序。
1. ES6数组排序从小到大
let arr = [3, 2, 1, 4];
arr.sort((a, b) => a - b);
console.log(arr); // [1, 2, 3, 4]
2. ES6数组排序sort从大到小
let arr = [3, 2, 1, 4];
arr.sort((a, b) => b - a);
console.log(arr); // [4, 3, 2, 1]
五、其他语言数组排序
除了ES6外,其他语言也提供了很多数组排序的方法。
1. C++数组排序
#include <algorithm>
#include <iostream>
using namespace std;
int main() {
int arr[] = {3, 2, 1, 4};
sort(arr, arr + 4);
for(int i = 0; i < 4; i++) {
cout << arr[i] << " ";
}
return 0;
}
// 输出:1 2 3 4
2. 数组排序C语言函数
#include <stdio.h>
#include <stdlib.h>
int cmp(const void* a, const void* b) {
return (*(int*)a - *(int*)b);
}
int main() {
int arr[] = {3, 2, 1, 4};
qsort(arr, 4, sizeof(int), cmp);
for(int i = 0; i < 4; i++) {
printf("%d ", arr[i]);
}
return 0;
}
// 输出:1 2 3 4
3. C语言数组排序
#include <stdio.h>
void bubbleSort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int arr[] = {3, 2, 1, 4};
bubbleSort(arr, 4);
for(int i = 0; i < 4; i++) {
printf("%d ", arr[i]);
}
return 0;
}
// 输出:1 2 3 4
六、ES6数组对象按字段排序
在ES6中,我们可以按照对象中的某个字段进行排序。
let arr = [
{name: 'Tom', age: 18},
{name: 'Bob', age: 20},
{name: 'Jim', age: 19}
];
arr.sort((a, b) => a.age - b.age);
console.log(arr);
// 输出:
// [
// {name: "Tom", age: 18},
// {name: "Jim", age: 19},
// {name: "Bob", age: 20}
// ]
在sort方法中,我们传入的比较函数将数组中的每个对象作为参数,然后按照对象的age字段进行排序。