js的排序問題

sort()的使用

1 簡單數(shù)組簡單排序

<script type="text/javascript"> var arr=new Array(1,8,7,6); arr.sort(); console.log(arr);//[ 1, 6, 7, 8 ] </script>


2 簡單數(shù)組自定義排序

<script type="text/javascript"> var arr=new Array(1,8,7,6); arr.sort(function(a,b){return b-a}); console.log(arr);//[ 8, 7, 6, 1 ] </script> //a,b表示數(shù)組中的任意兩個元素,a-b輸出從小到大排序,b-a輸出從大到小排序。(若return > 0 b前a后;reutrn < 0 a前b后;a=b時存在瀏覽器兼容簡化一下:)


3 簡單對象List自定義屬性排序

<script type="text/javascript"> var objectList = new Array(); function Persion(name,age){ this.name=name; this.age=age; } objectList.push(new Persion('jack',20)); objectList.push(new Persion('tony',25)); objectList.push(new Persion('stone',26)); objectList.push(new Persion('mandy',23)); //按年齡從小到大排序 objectList.sort(function(a,b){ return a.age-b.age}); for(var i=0;i<objectList.length;i++){ document.writeln('<br />age:'+objectList[i].age+' name:'+objectList[i].name); } </script>


4 簡單對象List對可編輯屬性的排序
<script type="text/javascript"> var objectList2 = new Array(); function WorkMate(name,age){ this.name=name; var _age=age; this.age=function(){ if(!arguments) { _age=arguments[0]; }else { return _age; }} } objectList2.push(new WorkMate('jack',20)); objectList2.push(new WorkMate('tony',25)); objectList2.push(new WorkMate('stone',26)); objectList2.push(new WorkMate('mandy',23)); //按年齡從小到大排序 objectList2.sort(function(a,b){return a.age()-b.age(); }); for(var i=0;i<objectList2.length;i++){ console.log(objectList2[i].name+':'+objectList2[i].age()+';'); } </script>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 工廠模式類似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品,去做同樣的事情,實(shí)現(xiàn)同樣的效果;這時候需要使用工廠模式。簡單...
    舟漁行舟閱讀 7,842評論 2 17
  • 問答 數(shù)組方法里push、pop、shift、unshift、join、split分別是什么作用。(*) var ...
    風(fēng)骨來客閱讀 358評論 0 0
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile麗語閱讀 3,865評論 0 6
  • 今天下午時間比較少,臨摹了pinterest上的一幅簡筆圖,原圖不是彩鉛的,自己隨便涂的顏色。 小清新一下吧。
    Joy_RY閱讀 458評論 0 2
  • 曾經(jīng)的海誓山盟,曾經(jīng)的甜言蜜語,以及曾經(jīng)的你。 我們總是在懵懂的青春里去追尋我們模糊的愛,總是在懵懂的年紀(jì)下許...
    夜神殤閱讀 340評論 0 0