JavaScript数组排序怎样实现

avatar
作者
猴君
阅读量:0

在JavaScript中,可以使用数组的.sort()方法对数组进行排序。默认情况下,.sort()方法将数组元素转换为字符串并按照字符Unicode编码顺序进行排序。如果需要按照其他规则排序,可以向.sort()方法提供一个自定义的比较函数。

以下是一些示例:

  1. 使用默认排序规则(按照字符Unicode编码顺序):
const fruits = ['apple', 'banana', 'kiwi', 'mango']; fruits.sort(); console.log(fruits); // 输出: ["apple", "banana", "kiwi", "mango"] 
  1. 使用自定义排序规则(例如,按照数字大小):
const numbers = [40, 100, 2, 67]; numbers.sort((a, b) => a - b); console.log(numbers); // 输出: [2, 40, 67, 100] 

在自定义比较函数中,如果返回值小于0,则a会排在b之前;如果返回值等于0,则ab的顺序不变;如果返回值大于0,则b会排在a之前。

注意:.sort()方法会直接修改原数组,而不是创建一个新的排序后的数组。如果需要保留原数组,可以在排序前创建一个数组的副本,例如使用slice()方法或扩展运算符(...):

const originalNumbers = [40, 100, 2, 67]; const sortedNumbers = originalNumbers.slice().sort((a, b) => a - b); console.log(sortedNumbers); // 输出: [2, 40, 67, 100] console.log(originalNumbers); // 输出: [40, 100, 2, 67] 

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!