JS sort方法基于數(shù)組對象屬性值排序
sort方法接收一個(gè)函數(shù)作為參數(shù),這里嵌套一層函數(shù)用來接收對象屬性名,其他部分代碼與正常使用sort方法相同.
var arr = [ {name:’zopp’,age:0}, {name:’gpp’,age:18}, {name:’yjj’,age:8}];function compare(property){ return function(a,b){ var value1 = a[property]; var value2 = b[property]; return value1 - value2; }}console.log(arr.sort(compare(’age’)))
如何根據(jù)參數(shù)不同,來確定是升序排列,還是降序排序呢?
/**數(shù)組根據(jù)數(shù)組對象中的某個(gè)屬性值進(jìn)行排序的方法 * 使用例子:newArray.sort(sortBy(’number’,false)) //表示根據(jù)number屬性降序排列;若第二個(gè)參數(shù)不傳遞,默認(rèn)表示升序排序 * @param attr 排序的屬性 如number屬性 * @param rev true表示升序排列,false降序排序 * */ sortBy: function(attr,rev){ //第二個(gè)參數(shù)沒有傳遞 默認(rèn)升序排列 if(rev == undefined){ rev = 1; }else{ rev = (rev) ? 1 : -1; }return function(a,b){ a = a[attr]; b = b[attr]; if(a < b){return rev * -1; } if(a > b){return rev * 1; } return 0; } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 秒殺場景的緩存、隊(duì)列、鎖使用Redis優(yōu)化設(shè)計(jì)方案2. 讀大數(shù)據(jù)量的XML文件的讀取問題3. ASP實(shí)現(xiàn)加法驗(yàn)證碼4. JSP的Cookie在登錄中的使用5. ASP腳本組件實(shí)現(xiàn)服務(wù)器重啟6. css進(jìn)階學(xué)習(xí) 選擇符7. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera8. HTML DOM setInterval和clearInterval方法案例詳解9. WML語言的基本情況10. XHTML 1.0:標(biāo)記新的開端
