基于JavaScript实现Json数据根据某个字段(json中的某个属性)进行排序
来源:互联网 发布:淘宝卖小饰品 编辑:程序博客网 时间:2024/04/28 20:47
在实际开发中,有一种需求是当前台获取后台传过来的json数据时,比如,需要按照json数据中查询的某个属性(某个字段)进行排序,好比,我需要显示某个事项要按照第1阶段、第2阶段等等以此类推的显示。我的json中查询到数据对应的阶段和阶段内容,那么如果我不进行任何处理,那么显示的时候,遍历josn数据显示,数据显示出来就不能按照顺序进行显示,所以我们必须对json数据进行一个排序后再进行输出。其中,js中自带的sort()方法可以对js数组进行排序。但它的排序是按照字符编码排序的,所以一般我们排序都是按照json中的某个数字类型的字段进行排序。所以我们需要重写sort函数。
1、根据字符串字段进行排序:
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/*
* @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;
}
2、json对象数组按对象属性(数字类型)排序
遍历将json对象,将其中的每个对象push到一个js数组对象中。
var
array = [
{name:
'a'
, phone: 1},
{name:
'b'
, phone: 5},
{name:
'd'
, phone: 3},
{name:
'c'
, phone: 4}
]
array.sort(getSortFun(
'desc'
,
'phone'
));
function
getSortFun(order, sortBy) {
var
ordAlpah = (order ==
'asc'
) ?
'>'
:
'<'
;
var
sortFun =
new
Function(
'a'
,
'b'
,
'return a.'
+ sortBy + ordAlpah +
'b.'
+ sortBy +
'?1:-1'
);
return
sortFun;
}
alert(JSON.stringify(array));
阅读全文
0 0
- 基于JavaScript实现Json数据根据某个字段(json中的某个属性)进行排序
- tree型的json数据按照json的某个字段对子节点进行排序
- Python 针对Json中某个关键字段进行排序
- JavaScript 对象数组,根据某个对象属性进行排序
- 根据类中的某个属性对类进行排序
- 按照列表中的某个字段的属性进行排序
- Json去除某个字段
- 根据List其中某个属性进行排序
- 根据json里的某个key对json数据进行分组
- 移除JSON对象中的某个属性
- 移除JSON对象中的某个属性
- 移除JSON对象中的某个属性
- js对象数组(JSON) 根据某个共同字段 分组
- js对象数组(JSON) 根据某个共同字段 分组
- jQuery如何获取Json中的某个数据。
- 去掉json数据中的某个键
- leanclude 根据某个字段排序
- 对List中的某个属性进行排序
- [BZOJ1563]诗人小G(1d1d动态规划)
- Ubuntu安装MySQL
- iOS中的.a文件
- makefile中使用shell 命令
- 五十个小技巧提高PHP执行效率
- 基于JavaScript实现Json数据根据某个字段(json中的某个属性)进行排序
- linux下文件共享--挂载(monut)
- js实现继承的几种方法
- 解析HTTP协议六种请求方法,get,head,put,delete,post有什么区别
- webpack安装流程
- HTML5模板引擎 Thymeleaf 教程
- 一道走迷宫算法题python实现
- Android驱动程序开发-JNI开发环境搭建+示例程序 (windows10 64位)
- 3.项目的目录结构