JS 数组排序方法 - sortFun

简介: 在前端开发中,经常需要对数组进行排序操作。在 JavaScript 中,数组的排序方法是 sort(),但是它并不支持根据指定的字段进行排序。因此,我们需要自己实现一个根据指定字段进行排序的方法。本文将介绍一个基于 JavaScript 的数组排序方法 sortFun,它可以根据指定的字段进行排序,并支持升序和降序两种排序方式。

在前端开发中,经常需要对数组进行排序操作。在 JavaScript 中,数组的排序方法是 sort(),但是它并不支持根据指定的字段进行排序。因此,我们需要自己实现一个根据指定字段进行排序的方法。本文将介绍一个基于 JavaScript 的数组排序方法 sortFun,它可以根据指定的字段进行排序,并支持升序和降序两种排序方式。

1. 排序方法 sortFun

sortFun 是一个 JavaScript 函数,可以通过传递三个参数来对数组进行排序。具体的函数定义如下:

/**
 * @method sortFun
 * @param arr 要传递的排序对象数组
 * @param name 要传递的排序字段
 * @param type 要传递的排序类型 默认升序:order 降序:desc
 */
const sortFun = (arr, name, type) => {
  const compare = (prop) => {
    return function(obj1, obj2) {
      let val1 = obj1[prop];
      let val2 = obj2[prop];
      if (val1 < val2) {
        return -1;
      } else if (val1 > val2) {
        return 1;
      } else {
        return 0;
      }
    }
  }
  if (type == 'desc') {
    return arr.sort(compare(name));
  } else {
    return arr.sort(compare(name)).reverse();
  }
}

其中,arr 是要排序的数组,name 是要排序的字段名,type 是排序类型,可以是 'order'(升序,默认值)或 'desc'(降序)。函数内部使用了 compare 函数来定义排序规则,根据指定的字段名对数组中的元素进行排序。

2. 排序规则 compare

compare 函数是 sortFun 函数内部定义的,它接受一个参数 prop,表示要根据哪个字段进行排序。具体的函数定义如下:

const compare = (prop) => {
  return function(obj1, obj2) {
    let val1 = obj1[prop];
    let val2 = obj2[prop];
    if (val1 < val2) {
      return -1;
    } else if (val1 > val2) {
      return 1;
    } else {
      return 0;
    }
  }
}

其中,obj1obj2 分别表示要比较的两个对象,prop 表示要根据哪个字段进行排序。函数内部通过访问对象的属性来获取相应的值,然后进行比较。如果第一个对象的属性值小于第二个对象的属性值,则返回 -1;如果第一个对象的属性值大于第二个对象的属性值,则返回 1;如果两个对象的属性值相等,则返回 0。

3. 排序示例

使用 sortFun 函数进行排序非常简单,只需要传递要排序的数组、要排序的字段名和排序类型即可。下面是一些示例代码:

const arr = [
  { name: 'Tom', age: 20 },
  { name: 'Jerry', age: 18 },
  { name: 'John', age: 25 }
];
// 按 name 字段升序排序
const sortedArr1 = sortFun(arr, 'name', 'order');
console.log(sortedArr1); // [{ name: 'Jerry', age: 18 }, { name: 'John', age: 25 }, { name: 'Tom', age: 20 }]
// 按 age 字段升序排序
const sortedArr2 = sortFun(arr, 'age', 'order');
console.log(sortedArr2); // [{ name: 'Jerry', age: 18 }, { name: 'Tom', age: 20 }, { name: 'John', age: 25 }]
// 按 name 字段降序排序
const sortedArr3 = sortFun(arr, 'name', 'desc');
console.log(sortedArr3); // [{ name: 'Tom', age: 20 }, { name: 'John', age: 25 }, { name: 'Jerry', age: 18 }]

从上面的示例可以看出,`sortFun` 函数非常方便易用,可以根据不同的字段和排序类型对数组进行排序。

4. 总结

本文介绍了一个 JavaScript 数组排序方法 `sortFun`,它可以根据指定的字段进行排序,并支持升序和降序两种排序方式。具体的实现原理是定义一个 `compare` 函数,根据指定的字段对数组中的元素进行比较,然后使用 JavaScript 数组对象的 `sort()` 和 `reverse()` 方法对数组进行排序和反转操作。 希望本文能够帮助大家更好地理解 JavaScript 数组的排序操作。如果有任何问题或建议,欢迎在评论区留言。

作者:Emo_TT。

相关文章
|
12天前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
24天前
|
缓存 监控 前端开发
JavaScript 实现大文件上传的方法
【10月更文挑战第17天】通过以上步骤和方法,我们可以实现较为可靠和高效的大文件上传功能。当然,具体的实现方式还需要根据实际的应用场景和服务器要求进行调整和优化。
|
11天前
|
JavaScript 前端开发 索引
js中DOM的基础方法
【10月更文挑战第31天】这些DOM基础方法是操作网页文档结构和实现交互效果的重要工具,通过它们可以动态地改变页面的内容、样式和行为,为用户提供丰富的交互体验。
|
11天前
|
缓存 JavaScript UED
js中BOM中的方法
【10月更文挑战第31天】
|
22天前
|
前端开发 JavaScript 算法
使用 JavaScript 数组方法实现排序与去重
【10月更文挑战第21天】通过灵活运用 `sort()` 方法和 `filter()` 方法,我们可以方便地实现数组的排序和去重。同时,深入理解排序和去重的原理,以及根据实际需求进行适当的优化,能够更好地应对不同的情况。可以通过实际的项目实践来进一步掌握这些技巧,并探索更多的应用可能性。
97 59
|
11天前
|
JavaScript 前端开发
.js方法参数argument
【10月更文挑战第26天】`arguments` 对象为JavaScript函数提供了一种灵活处理参数的方式,能够满足各种不同的参数传递和处理需求,在实际开发中具有广泛的应用价值。
28 7
|
12天前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
17天前
|
JavaScript 前端开发 Go
异步加载 JS 的方法
【10月更文挑战第24天】异步加载 JavaScript 是提高网页性能和用户体验的重要手段。通过使用不同的方法和技术,可以实现灵活、高效的异步加载 JavaScript。在实际应用中,需要根据具体情况选择合适的方法,并注意处理可能出现的问题,以确保网页能够正常加载和执行。
|
28天前
|
人工智能 JavaScript 网络安全
ToB项目身份认证AD集成(三完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法
本文详细介绍了如何使用 `ldapjs` 库在 Node.js 中实现与 Windows AD 的交互,包括用户搜索、身份验证、密码修改和重置等功能。通过创建 `LdapService` 类,提供了与 AD 服务器通信的完整解决方案,同时解决了中文字段在 LDAP 操作中被转义的问题。
|
12天前
|
JavaScript 前端开发 开发者