首頁  >  文章  >  web前端  >  擴展js物件數組的OrderByAsc和OrderByDesc方法實作思路_javascript技巧

擴展js物件數組的OrderByAsc和OrderByDesc方法實作思路_javascript技巧

WBOY
WBOY原創
2016-05-16 17:33:311519瀏覽

看了一段時間關於js原型的知識,js的擴展方法是基於原型的,如Array.prototype.XXXX就是給Array擴展XXX方法,然後數組都能使用這個方法了。

在物件陣列裡面常有依照屬性來排序的,升序,降序的,於是自己就想寫一個類似C#裡面的orderBy的方法,程式碼如下:

複製程式碼 程式碼如下:

Array.prototype.OrderByAsc = function (func) {
var m =};
for (var i = 0; i for (var k = 0; k if (func(this[i]) m = this[k];
this[k] = this[i];
this[i] = m;
}
}
}
return this;
}
Array.prototype.OrderByDesc = function (func) {
var m = {};
for (var i = 0; i for (var k = 0; k if (func(this[i]) > func(this[k])) {
m = this[k];
this[k] = this[i];
this[i] = m;
}
}
}
return this;
}

呼叫的方法如下:
複製程式碼


程式碼如下

var arr = [{ name: 'aaa', grade: 20 }, { name: 'ccc', grade: 30 }, { name: 'bbb', grade: 40 }];
var orderArr = arr.OrderByDesc(function (a) {
return a.grade;
});
然後輸出一下,看一下結果吧: 複製程式碼

程式碼如下:


for (var i = 0; i document.write(orderArr[i].name);
} 本人js菜鳥,如果有什麼想法啥的,直接留言,互相交流一下
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn