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

 

相關文章
相關標籤/搜索