首页 > 其他分享 >记:关于使用.sort((a,b) => a>b)排序函数方式引发的问题

记:关于使用.sort((a,b) => a>b)排序函数方式引发的问题

时间:2022-12-21 17:45:01浏览次数:35  
标签:sort 返回 return 函数 h5 排序

需求: 对后台返回的数据进行升序排序处理后展示到页面上。

环境:基于uniapp开发的h5页面;vue2.0

问题:在浏览器h5页面上数据是正确的,但是在钉钉等App内嵌h5页面的情况下,数据发生了错乱。

检查得知:代码中使用了sort排序,排序函数使用了.sort((a,b) => a>b)的方式。

验证:

1、我们采用.sort((a,b) => a>b)的方式对一维数组进行排序,并把排序后的结果打印到页面上。

具体代码如下:

// ui层代码
<view class="box">
  <div>
    使用.sort((a,b) => a>b)方式:{{arr1}}
  </div>
  <div>
    使用.sort((a,b) => a<b)方式:{{arr2}}
  </div>
  <div>
    使用.sort((a,b) => a-b)方式:{{arr3}}
  </div>
  <div>
    使用.sort((a,b) => b-a)方式:{{arr4}}
  </div>
</view>

// js代码
export default {
  data() {
    return {
      originalArr: [9,2,1,80]
    }
  },
  computed: {
    arr1() {
      return this.originalArr.sort((a,b) => a > b)
    },
    arr2() {
      return this.originalArr.sort((a,b) => a < b)
    },
    arr3() {
      return this.originalArr.sort((a,b) => a - b)
    },
    arr4() {
      return this.originalArr.sort((a,b) => b - a)
    },
  }
}

在浏览器h5页面上展示结果:

 

 

 在App内嵌h5页面下展示结果:

由此可见,当使用标准的排序函数写法时,我们可以得到想要的结果,但是如果使用.sort((a,b) => a>b)方式想达到相同的目的时,我们发现 在App内嵌h5的情况下是不适用的。

原因分析:

 .sort((a,b) => a>b)的排序方式是不稳定的,是否起作用取决于当前使用的浏览器和输入数组。因为sort函数期望返回正数,0或负数。而表达式 a> b 或 a< b 返回一个布尔值,通过某些浏览器的特定实现 该布尔值将转换为0或1,而某些浏览器内核下,这种方法不能被解析成 排序,因此出现数据错乱的问题。

解决方法:

使用标准的排序函数写法:

语法:arrayObject.sort(sortby);参数sortby可选。规定排序顺序。必须是函数。

sort()方法主要是用于对数组进行排序,默认情况下该方法是将数组元素转换成字符串,然后按照ASC码进行排序,实例如下:

var arr = [23,12,1,34,116,8,18,37,56,50];
console.log(arr.sort());        // 输出:[1, 116, 12, 18, 23, 34, 37, 50, 56, 8]

上面的代码没有按照数值的大小对数字进行排序,要实现这一点,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字(正数、0或者负数)。

比较函数写法:

function sortNumber(a, b){
   return a - b; //这里返回的是他们的差值,如果是大于0的值,就会将b排在前面,如果小于0,
   就会将a排在前面,如果是0的话,就随便。(冒泡排序法!!)
}

比较函数应该具有两个参数 a 和 b,其返回值如下:  

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
  • 若 a 等于 b,则返回 0。
  • 若 a 大于 b,则返回一个大于 0 的值。

 接下来我们使用排序函数实现对数字大小排序,实例如下:

var arr = [23,12,1,34,116,8,18,37,56,50];
// 写法一
function sequence(a,b){
  if (a>b) {
    return 1;
  }else if(a<b){
     return -1
  }else{
    return 0;
  }
}
console.log(arr.sort(sequence));    // 输出:[1, 8, 12, 18, 23, 34, 37, 50, 56, 116]

// 写法二:直接把排序函数写到sort()方法里面
var arr2 = arr.sort(function(a,b){
  if (a>b) {
    return 1;
  }else if(a<b){
    return -1
    }else{
    return 0;
  }  
})
console.log(arr2);    // 输出:[1, 8, 12, 18, 23, 34, 37, 50, 56, 116]

也可以进行简化:

因为:若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值; 若 a 等于 b,则返回 0;若 a 大于 b,则返回一个大于 0 的值。实例如下:

console.log(arr.sort(function(a,b){ return a - b}));        // 输出:[1, 8, 12, 18, 23, 34, 37, 50, 56, 116]

 

标签:sort,返回,return,函数,h5,排序
From: https://www.cnblogs.com/morango/p/16996766.html

相关文章

  • 快速排序
    快速排序时间复杂度:O(logn)算法步骤:将数据根据一个值按照大小分为左右两边,左面小于此值,右面大于此值将两边数据调用步骤1将所有数据合并优化:标准的快......
  • 【数据结构-排序】内部排序
    目录1直接插入排序1.1算法简要思想1.2算法特性2希尔排序2.1算法简要思想2.2手动模拟2.3算法特性3冒泡排序3.1算法简要思想3.2算法特性4快速排序4.1算法思路4.2......
  • mysql分组后限制条数和排序
    废话少数直接上需求和解决方案需求:分组查询指定条数 这是我的表表名news,查询class_id为1和2的数据各三条这是sql:selectn1.*fromnewsn1wheren1.`class_id`in......
  • C++函数参数传递的三种方式之 指针传递(地址传递)
    前景提示:因为目前是对C#比较熟悉,而C++基础堪忧,在学习CGAL时,发现CGAL封装的函数体的参数中动不动就出现'&'、'*'这两个字符,接而疑惑于心中油然而生。//函数定义conv......
  • 四大排序
    ***以下排序皆以升序为例***插入排序1.1直接插入排序1.1.1单趟排序思想(三种情况)对于第一张图片中的数据,我们设置一个tmp保存最后一个数据,设置end表示5的下标。在这串数据......
  • KingbaseES 基于SQL的函数过程
    什么是SQL函数?SQL函数包体是一些可执行的SQL语言。同时包含1条以上的查询,但是函数只返回最后一个查询(必须是SELECT)的结果。除非SQL函数声明为返回void,否则最后一条语......
  • 构造函数的继承和派生类选择基类的构造方法
    对于构造方法的继承需要注意2点:初始化一个对象时,基类baseclass的构造方法总是会首先执行基类baseclass的有参构造方法不会被继承,在派生类中需要我们重新定义新的构造......
  • C++排列函数
    https://blog.csdn.net/m0_37890541/article/details/105104045#include<iostream>#include<cstring>#include<algorithm>usingnamespacestd;constintMAXN=......
  • HeapSort堆排序原理与实现
    HeapSort堆排序原理与实现  堆排序是比较重要的数据结构,其主要优点是通过排序二叉树的特性能够记录每个数之间的大小关系,以至于不需要重复比较,对于海量数据排序问题可以减......
  • C# 类的构造函数以及析构函数
    类的构造函数以及析构函数构造函数在类初始化的时候被调用,可以方便提前传参。usingSystem;namespaceMyNameSpace{classDemo{privatedoubleleng......