首頁 > web前端 > js教程 > 主體

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

WBOY
發布: 2016-05-16 17:33:31
原創
1519 人瀏覽過

看了一段時間關於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菜鳥,如果有什麼想法啥的,直接留言,互相交流一下
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!