js中sort的使用(二)
現在我們討論第二種情況的排序。
第一種情況是整個陣列都是服務端給過來的,所以裡面的value值也是服務端發的。那麼,如果服務端只發id給你呢?
這種情況就是,你現在有一個數組arr1,服務端給你一個數組比如arr2。
let arr1 = [ {id:1,name:"a"}, {id:2,name:"b"}, {id:3,name:"c"}, {id:4,name:"d"}, {id:5,name:"e"}, {id:6,name:"f"}, {id:7,name:"g"}, {id:8,name:"h"}, {id:9,name:"i"}, {id:10,name:"j"} ]; let arr2 = [ {id:1}, {id:2}, {id:3}, {id:5} ];
arr2裡面的資料就是已領取的項,所以我們排序後arr1的結果為:4,6,7,8,9,10,1,2,3,5。
那麼我們只要判斷arr1裡面的項的id有等於arr2裡面的項的id的時候,就把arr1的那個項拋到陣列的最後面就行了,所以:
let num = 0; for(let key in arr2) { for(let i = 0,l = arr1.length; i < l; i++) { if(arr1[i].id == arr2[key].id){ let str = arr1.splice(i,1); arr1.unshift(str[0]); arr1.push(str[0]); num ++; } } } arr1.splice(0,num)
哈哈,這種方法雖然也可以。但是不建議,就像第一章所說的,接下來我們來看看sort方法吧。
首先我們為arr2寫一個方法,用來判斷所傳資料是否存在於arr2中
function rank(val) { for(let key in arr2){ if(val == arr2[key].id){ return 1; } } return 0; }
然後吧arr1中id的值傳入rank()裡面就行了
arr1.sort((a,b)=>{ if(rank(a.id) == 1 && rank(b.id) != 1){ return 1; }else if(rank(a.id) != 1 && rank(b.id) == 1){ return -1; } return 0; })
(完)