javascript使用sort()方法排序,当数据缺失时排序处理方法

今天遇到了个排序问题,当需要排序的字段缺少数据时,如下图

在这里插入图片描述
出现此问题的原因就是当数据 undefined 的时候,函数无法正确判断返回
下面贴出完整的代码, 亲测可用哦!!!

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>sort排序处理</title>
</head>
<body>
	<div><button onclick="bigToSmall()">从大到小</button></div>
	<div><button onclick="smallToBig()">从小到大</button></div>
	
	<script>
	var arr = [
		{total_net_value: 123},
		{total_net_value: 124},
		{total_net_value: 12},
		{total_net_value: 133},
		{total_net_value: 33},
		{},
		{total_net_value: 143},
		{total_net_value: 23},
		{},
		{total_net_value: 120},
		{total_net_value: 213},
		{total_net_value: 13},
	]

	function compare(property, type){
	  return function(a,b){
	    let value1 = a[property];
	    let value2 = b[property];
	    // console.log(value1, value2)
	    if (value1 == undefined) { // 当第一个值不存在时, 默认排序结果最大
	    	return 1
	    }
    	if (value2 == undefined) { // 当第二个值不存在时, 默认排序结果最小
	    	return -1
	    }
	    // 这样处理过后,只要数据不存在默认排在最后面
	    if (type == 'big') {
	    	return value2 - value1
	    }else {
	    	return value1 - value2
	    }
	  }
	}
	console.log('排序前', arr)
	
	function bigToSmall () {
		arr.sort(compare('total_net_value' ,'big'))
		console.log('排序后', arr)
	}
	function smallToBig () {
		arr.sort(compare('total_net_value', 'small'))
		console.log('排序后', arr)
	}
	

	</script>
</body>
</html>
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: JavaScript中的sort方法是用来对数组进行排序的。它可以按照指定的排序规则对数组元素进行排序排序后的结果会替换原来的数组。sort方法默认按照Unicode编码的顺序进行排序,但是也可以通过传入一个比较函数来指定排序规则。比较函数接收两个参数,分别是要比较的两个元素,如果第一个元素应该排在第二个元素之前,则返回一个负数,如果第一个元素应该排在第二个元素之后,则返回一个正数,如果两个元素相等,则返回。 ### 回答2: JavaScript中提供了sort()方法,可以用来对数组进行排序sort()方法接受一个可选的比较函数,用于指定排序的方式。 使用sort()方法进行排序,默认情况下会将数组中的元素转换为字符串并进行字典排序。例如,对于数组['item1','item10','item2'],进行默认排序会得到['item1','item10','item2'],这是不符合我们预期的。因此,需要传入一个比较函数来指定排序方式。 比较函数有两个参数,通常称为a和b。如果a应该排在b前面,比较函数应该返回负数;如果a应该排在b后面,比较函数应该返回正数;如果a和b相等,比较函数应该返回0。 例如,对于上述数组,如果我们想要按照数字大小进行排序,则可以传入以下比较函数: function compare(a, b) { return parseInt(a.substring(4)) - parseInt(b.substring(4)); } 然后,我们可以使用该比较函数进行排序: var arr = ['item1','item10','item2']; arr.sort(compare); // 得到['item1','item2','item10'] 除了使用自定义比较函数外,还可以使用内置的比较函数。例如,如果想要按照升序排序,则可以使用以下代码: var arr = [5, 3, 9, 2, 8]; arr.sort(function(a, b){return a-b;}); // 得到[2, 3, 5, 8, 9] 如果想要按照降序排序,则可以将比较函数修改为: var arr = [5, 3, 9, 2, 8]; arr.sort(function(a, b){return b-a;}); // 得到[9, 8, 5, 3, 2] sort()方法在原数组上进行排序,并返回排序后的数组。因此,可以将其结果直接赋值给原数组,也可以将其结果保存到一个新数组中。 总之,JavaScript中的sort()方法是一个非常强大的工具,可以用来对数组进行排序。通过使用自定义比较函数,我们可以实现各种不同的排序方式。 ### 回答3: JavaScript中的sort()方法是一种通用的数组排序方法,其功能是根据特定的排序规则重排数组。使用sort()方法可以轻松地对数组进行排序,以便将其按字母顺序、数字大小、日期等方式排列。 sort()方法的用法非常简单。只需使用以下语法: array.sort(sortFunction); 其中,sortFunction是一个可选的参数,它定义了用于比较两个值的规则。如果省略此参数,sort()方法将默认使用“字母顺序”对数组进行排序sort()方法工作原理是将数组中的每个元素与其他元素进行比较,并根据指定的规则进行重排。具体规则取决于sortFunction。如果sortFunction返回较小的值,则第一个元素将排在前面,否则它将被排在第二个元素之后。 sortFunction要么返回负数、要么返回0、要么返回正数。如果返回负数,那么第一个比较的元素将在第二个之前。如果返回0,那么两个元素的顺序不变。 如果返回正数,那么第二个比较元素将在第一个之前。 除了sortFunction之外,sort()方法还支持一些额外的参数。这些参数旨在帮助您更好地控制排序的方式,以便满足特殊需求。其中一些参数包括: - reverse:表示是否要倒序排列数组。 - compareFunction:一个可以自定义比较函数。 - locale:表示用于排序的特定语言环境。 根据不同的需求,JavaScript sort()方法提供了不同的排序函数,使得开发人员可以灵活地对数组进行排序。在实际应用的过程中,可以根据具体场景选取最适合的排序函数,来提高代码的效率和可读性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值