js對jsonArray的操做

上一篇寫了關於java中Gson對jsonArray的排序處理,這裏介紹js中對jsonArray處理,javascript

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Test</title>
<script type="text/javascript">
var data = [
    {recordId: 1, recordNo: "PC140", userId: 3, recordType: 9,recordInMoney: 25},
    {recordId: 5, recordNo: "PC329", userId: 1, recordType: 3,recordInMoney: 13},
    {recordId: 2, recordNo: "PC458", userId: 7, recordType: 9,recordInMoney: 50}
];

/*
 * @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,'recordNo', true));

//filter方法
function gtFilter(value) {
   return value.recordId > 3;
}
console.log(data.filter(gtFilter));

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

測試結果html

 

相關文章
相關標籤/搜索