天天看點

js sort() 排序用法(轉載)

sort() 方法用于對數組的元素進行排序,并傳回數組。預設排序順序是根據字元串Unicode碼點。

文法:array.sort(fun);參數fun可選。規定排序順序。必須是函數。

注:如果調用該方法時沒有使用參數,将按字母順序對數組中的元素進行排序,說得更精确點,是按照字元編碼的順序進行排序。

如果想按照其他規則進行排序,就需要提供比較函數,該函數要比較兩個值,然後傳回一個用于說明這兩個值的相對順序的數字。比較函數應該具有兩個參數 a 和 b,其傳回值如下:

若 a 小于 b,在排序後的數組中 a 應該出現在 b 之前,則傳回一個小于 0 的值。

若 a 等于b,則傳回 0。

若 a 大于 b,則傳回一個大于 0 的值。

簡單點就是:比較函數兩個參數a和b,傳回a-b 升序,傳回b-a 降序

//注:原數組發生改變

例:

1.不傳參數,将不會按照數值大小排序,按照字元編碼的順序進行排序;

var arr = ['General','Tom','Bob','John','Army'];

var resArr = arr.sort();

console.log(resArr);//輸出 ["Army", "Bob", "General", "John", "Tom"]

var arr2 = [30,10,111,35,1899,50,45];

var resArr2 = arr2.sort();

console.log(resArr2);//輸出 [10, 111, 1899, 30, 35, 45, 50]

2.傳入參數,實作升序,降序;

var arr3 = [30,10,111,35,1899,50,45];

arr3.sort(function(a,b){

  return a - b;

})

console.log(arr3);//輸出 [10, 30, 35, 45, 50, 111, 1899]

var arr4 = [30,10,111,35,1899,50,45];

arr4.sort(function(a,b){

  return b - a;

console.log(arr4);//輸出 [1899, 111, 50, 45, 35, 30, 10]

3.根據數組中的對象的某個屬性值排序;

var arr5 = [{id:10},{id:5},{id:6},{id:9},{id:2},{id:3}];

arr5.sort(function(a,b){

  return a.id - b.id

console.log(arr5);

//輸出新的排序

// {id: 2}

// {id: 3}

// {id: 5}

// {id: 6}

// {id: 9}

// {id: 10}

改成參數方法

arr5.sort(sortBy(attr,rev));

//attr:根據該屬性排序;rev:升序1或降序-1,不填則預設為1

sortBy(attr,rev){

  if( rev==undefined ){ rev=1 }else{ (rev)?1:-1; }

  retrun function (a,b){

     a=a[attr];

   b=b[attr];

   if(a<b){ return rev*-1}

     if(a>b){ return rev* 1 }

   retrun 0;

       }

}

4.根據數組中的對象的多個屬性值排序,多條件排序;

var arr6 = [{id:10,age:2},{id:5,age:4},{id:6,age:10},{id:9,age:6},{id:2,age:8},{id:10,age:9}];

arr6.sort(function(a,b){

  if(a.id === b.id){//如果id相同,按照age的降序

    return b.age - a.age

  }else{

    return a.id - b.id

  }

console.log(arr6);

// {id: 2, age: 8}

// {id: 5, age: 4}

// {id: 6, age: 10}

// {id: 9, age: 6}

// {id: 10, age: 9}

// {id: 10, age: 2}

5、sort還時常用到拷貝!因為sort會改變原始資料的順序。

   var dataTemp= data.concat([]);

6、用sort排序,求最大值。

js sort() 排序用法(轉載)
js sort() 排序用法(轉載)

function getMax(arr) {
            if (arr != null && (arr instanceof Array) && arr.length > 0) {
                let arr2 = arr.concat([]);
                arr2.sort(function (a, b) { return a - b })
                let max = arr2[arr2.length - 1];
                console.log('max', max);
                return max;
            } 
            return null;
        }
        function getMax2(arr, name) {
            
            if (arr != null && (arr instanceof Array) && arr.length > 0) {
                let arr2 = arr.concat([]);
                arr2.sort(function (a, b) { return a[name] - b[name] })
                let max = arr2[arr2.length - 1][name];
                console.log('max', max);
                return max;
            }
            return null;
        }      

View Code

樹立目标,保持活力,gogogo!

繼續閱讀