基于JavaScript實(shí)現(xiàn)Json數(shù)據(jù)根據(jù)某個字段進(jìn)行排序
一.首先給大家介紹js中內(nèi)置的 sort() 方法
此方法默認(rèn)是按字母順序?qū)?shù)組中的元素進(jìn)行排序的,說得更精確點(diǎn),是按照字符編碼的順序進(jìn)行排序。
看如下例子:

當(dāng)數(shù)組中元素為 數(shù)字類型 時(shí),排序結(jié)果與我們設(shè)想的完全不同,因?yàn)槟J(rèn)是按照字符編碼的順序進(jìn)行排序的。
解決方案:sort() 方法接收一個可選參數(shù)(此參數(shù)必須是函數(shù)),我們可以自己定義排序規(guī)則,如下圖

二. 對 json 排序的具體實(shí)現(xiàn)
/*
* @description 根據(jù)某個字段實(shí)現(xiàn)對json數(shù)組的排序
* @param array 要排序的json數(shù)組對象
* @param field 排序字段(此參數(shù)必須為字符串)
* @param reverse 是否倒序(默認(rèn)為false)
* @return array 返回排序后的json數(shù)組
*/
function jsonSort(array, field, reverse) {
//數(shù)組長度小于2 或 沒有指定排序字段 或 不是json格式數(shù)據(jù)
if(array.length < 2 || !field || typeof array[0] !== "object") return array;
//數(shù)字類型排序
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;
}
PS:JS中:json對象數(shù)組按對象屬性排序
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));
數(shù)組本身有sort方法,可以指定排序函數(shù),因此可以動態(tài)生成一個排序函數(shù)來完成對按指定對象屬性排序的需求;
注意:sort后原數(shù)組序列會發(fā)生變化!!
- JS根據(jù)json數(shù)組多個字段排序及json數(shù)組常用操作
- JavaScript對JSON數(shù)組簡單排序操作示例
- JS實(shí)現(xiàn)json對象數(shù)組按對象屬性排序操作示例
- json格式數(shù)據(jù)的添加,刪除及排序方法
- json數(shù)據(jù)處理技巧(字段帶空格、增加字段、排序等等)
- JavaScript對JSON數(shù)據(jù)進(jìn)行排序和搜索
- Json按某個鍵的值進(jìn)行排序
- JSON 數(shù)字排序多字段排序介紹
- JS實(shí)現(xiàn)對json對象排序并刪除id相同項(xiàng)功能示例
- JS實(shí)現(xiàn)json數(shù)組排序操作實(shí)例分析
相關(guān)文章
Bootstrap導(dǎo)航簡單實(shí)現(xiàn)代碼
這篇文章主要介紹了Bootstrap導(dǎo)航的簡單實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
javascript中等于(==)與全等(===)的區(qū)別說明
等于(==)的情況下 只要值相同就返回True。而全等(===)的時(shí)候需要值和類型都要匹配才能返回True.2011-01-01
JS實(shí)現(xiàn)jQuery的append功能
jQuery中可以直接使用$el.append()為元素添加字符串型dom, 但是最近轉(zhuǎn)戰(zhàn)Vue, 再使用jQuery明顯不合適了, 所以通過查找資料, 封裝一個可以實(shí)現(xiàn)同樣效果的方法.2021-05-05

