对json数组进行排序和filter过滤

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>对json数组进行排序和filter过滤</title>
</head>
<body>
<script>



var data = [
	{recordId: 10, recordNo: "PPCZ_", userId: 1, recordType: 9, recordCode: "", recordInMoney: 1111},
	{recordId: 5, recordNo: "PPCZ_20170105170203", userId: 1, recordType: 9,recordInMoney: 11},
	{recordId: 2, recordNo: "PPCZ_20170105170201", userId: 1, recordType: 9,recordInMoney:500}
]


/*
 * @description		根据某个字段实现对json数组的排序
 * @param	 array	要排序的json数组对象
 * @param	 field	排序字段(此参数必须为字符串)
 * @param	 reverse  是否倒序(默认为false)
 * @return	array	返回排序后的json数组
*/
function jsonSort(array, field, reverse) {
	//数组长度小于2 或 没有指定排序字段 或 不是json格式数据
	if(array.length < 2 || !field || typeof array[0] !== "object") return array;
	//数字类型排序
	if(typeof array[0][field] === "number") {
		array.sort(function(x, y) { return x[field] - y[field]});
	}
	//字符串类型排序
	if(typeof array[0][field] === "string") {
		array.sort(function(x, y) { return x[field].localeCompare(y[field])});
	}
	//倒序
	if(reverse) {
		array.reverse();
	}
	return array;
}

            //使用方法 
console.log(jsonSort(data,'recordId'));

//filter方法
function gtFilter(value) {
   return value.recordId > 5
}

console.log(data.filter(gtFilter))



</script>
	
</body>
</html>

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值