上一篇寫了關於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