JS sort方法基于數(shù)組對(duì)象屬性值排序
sort方法接收一個(gè)函數(shù)作為參數(shù),這里嵌套一層函數(shù)用來(lái)接收對(duì)象屬性名,其他部分代碼與正常使用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ù)不同,來(lái)確定是升序排列,還是降序排序呢?
/**數(shù)組根據(jù)數(shù)組對(duì)象中的某個(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ù)沒(méi)有傳遞 默認(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; } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Nginx+php配置文件及原理解析2. 解決啟動(dòng)django,瀏覽器顯示“服務(wù)器拒絕訪問(wèn)”的問(wèn)題3. JSP數(shù)據(jù)交互實(shí)現(xiàn)過(guò)程解析4. css3溢出隱藏的方法5. python virtualenv和flask安裝沒(méi)有名為flask的模塊6. java中throws實(shí)例用法詳解7. CSS3實(shí)現(xiàn)動(dòng)態(tài)翻牌效果 仿百度貼吧3D翻牌一次動(dòng)畫(huà)特效8. Opencv+Python識(shí)別PCB板圖片的步驟9. ASP.NET MVC獲取多級(jí)類別組合下的產(chǎn)品10. 關(guān)于HTML5的img標(biāo)簽
