js中 sort排序出错的处理

js中 sort排序出错的处理

在开发过程中常会用到js排序的方法,在用sort排序时数果是数字排序会出现不是正常大小排序。如果没有指定比较方法时,元素会按照转换为的字符串的诸个字符的Unicode位点进行排序。例如当数字按由小到大排序时,151 出现在 2 之前,但因为(没有指明比较的方法),比较的数字会先被转换为字符串,所以在Unicode顺序上151要比 2 要靠前。

let arr = [151,0,5,2,58,5,85,5,54,87,19,9,2,1,35,89,6,47,1,1,3,56,95,8,5,80] 
arr.sort()
console.log(arr)

控制台打印结果是:

(26) [0, 1, 1, 1, 151, 19, 2, 2, 3, 35, 47, 5, 5, 5, 5, 54, 56, 58, 6, 8, 80, 85, 87, 89, 9, 95]

如果想达到数组从小到大排序时,需要对sort函数指明排序方法,如

            let arr = [151,0,5,2,58,5,85,5,54,87,19,9,2,1,35,89,6,47,1,1,3,56,95,8,5,80] 
            arr.sort((a,b)=>{
                if(a<b){
                    return -1
                }
                if(a>b){
                    return 1
                }
                return 0
            })
            console.log(arr)

控制台打印结果为:

[0, 1, 1, 1, 2, 2, 3, 5, 5, 5, 5, 6, 8, 9, 19, 35, 47, 54, 56, 58, 80, 85, 87, 89, 95, 151]

处理完毕

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScriptsort()是用于对数组进行排序的方法。sort()可以按照默认的字符顺序对数组的元素进行排序,也可以使用自定义的排序函数来指定排序规则。 默认情况下,sort()方法将数组元素转换为字符串,并按照Unicode码点进行排序。这意味着它在对数字进行排序时可能不会按照我们预期的顺序进行。 如果我们想要指定自定义的排序规则,我们可以通过传递一个比较函数作为参数来实现。比较函数接受两个参数,并根据这两个参数的关系返回一个负数、零或正数,来决定它们在排序结果的顺序。如果第一个参数应该排在第二个参数之前,则返回一个负数,如果它们的顺序应该保持不变,则返回零,如果第一个参数应该排在第二个参数之后,则返回一个正数。 下面是一个示例:假设我们有一个对象数组,每个对象具有name和age属性。我们可以使用sort()方法按照name属性的字母顺序对数组进行排序,可以使用如下的比较函数: ``` function compare(a, b) { if (a.name < b.name) { return -1; } if (a.name > b.name) { return 1; } return 0; } array.sort(compare); ``` 这样,数组将按照name属性的字母顺序进行排序。如果要按照age属性进行排序,只需相应地修改比较函数即可。 需要注意的是,sort()方法会修改原始数组,而不是返回一个新的排序后的数组。因此,在使用sort()方法之前,最好先创建原始数组的副本,以防止不需要的副作用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [jssort:JavaScript排序方法,将按给定数组对象的多个字段进行排序](https://download.csdn.net/download/weixin_42112894/18494492)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [js数组排序sort方法的原理分析](https://download.csdn.net/download/weixin_38535808/13209337)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Js sort排序使用方法](https://download.csdn.net/download/weixin_38615591/13064684)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值