JavaScript的sort函数

JavaScript 的 `Array.prototype.sort()` 方法用于对数组的元素进行排序,并返回排序后的数组。默认情况下,`sort` 方法将数组元素转换为字符串,并按照字符串的Unicode码点顺序进行排序。这意味着即使数组中的元素是数字,它们也会被先转换成字符串,然后再比较它们的字典序,这可能会导致非直观的排序结果。为了实现更复杂的排序逻辑,`sort` 方法可以接受一个可选的比较函数作为参数。

基本使用

默认排序(将元素视为字符串):

javascript 复制代码
const fruits = ['Banana', 'Orange', 'Apple', 'Mango'];
fruits.sort();
console.log(fruits); // 输出: ['Apple', 'Banana', 'Mango', 'Orange']

数值排序(使用比较函数):

javascript 复制代码
const numbers = [40, 100, 1, 5, 25];
numbers.sort((a, b) => a - b);
console.log(numbers); // 输出: [1, 5, 25, 40, 100]

比较函数

比较函数应该接受两个参数(我们通常称之为`a`和`b`),并根据以下规则返回一个值来确定它们的排序顺序:

  • 如果返回值 小于 0 ,则将`a`排在`b`之前。

  • 如果返回值 大于 0 ,则将`b`排在`a`之前。

  • 如果返回值 等于 0,则`a`和`b`的相对位置不变

示例(假设我们想根据字符串长度对数组进行排序)

javascript 复制代码
const items = ['Banana', 'Orange', 'Apple', 'Mango'];
items.sort((a, b) => a.length - b.length);//从小到大排序
console.log(items); // 输出: ['Apple', 'Mango', 'Banana', 'Orange']

注意

  • JavaScript的sort方法会就地 对数组进行排序,也就是说,原数组会被修改
  • 对于数值排序,直接使用默认排序可能会得到错误的结果 ,因此建议总是为数值排序提供一个比较函数。
相关推荐
用户298698530148 分钟前
在 React 中使用 JavaScript 将 Excel 转换为 SVG
前端·javascript·react.js
labixiong40 分钟前
手写Promise--微任务、静态方法、async/await 全搞懂(三)
前端·javascript
铁皮饭盒2 小时前
3行代码搞定页面截图,Bun.WebView真的简单
javascript
kyriewen15 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
山河木马16 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
tangdou36909865517 小时前
AI真好玩系列-2分钟快速了解DeepAgents | Quick Guide to DeepAgents in 2 Minutes
前端·javascript·后端
张元清17 小时前
React useIntersectionObserver Hook:懒加载与可见性检测(2026)
javascript·react.js
彭于晏爱编程18 小时前
纯 JS + Node,一个下午手搓了能读懂公司代码的 AI 助手,老板以为我转行了
前端·javascript
妙码生花18 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十四):眨眼小人登录页制作
前端·javascript·ai编程
妙码生花18 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十三):前端路由初始化
前端·javascript·ai编程