JS隨機打亂數(shù)組的方法小結(jié)

字號:


    JS中,要打亂數(shù)組有很多方法,網(wǎng)上流傳一個國外人寫的方法,我認(rèn)為是最精簡的了:
    function randomsort(a, b) {
        return Math.random()>.5 ? -1 : 1;
        //用Math.random()函數(shù)生成0~1之間的隨機數(shù)與0.5比較,返回-1或1
    }
    var arr = [1, 2, 3, 4, 5];
    arr.sort(randomsort);
    這里介紹下sort()函數(shù),在JS中Array對象里內(nèi)置了一個函數(shù):
    arrayobj.sort([sortfunction])
    此方法將 Array 對象進(jìn)行適當(dāng)?shù)呐判?;在?zhí)行過程中并不會創(chuàng)建新的 Array 對象。
    sortFunction為可選項。
    是用來確定元素順序的函數(shù)的名稱。如果這個參數(shù)被省略,那么元素將按照 ASCII 字符順序進(jìn)行升序排列。
    sortFunction方法有兩個參數(shù)。分別代表每次排序比較時的兩個數(shù)組項。sort()排序時每次比較兩個數(shù)組項都回執(zhí)行這個參數(shù),并把兩個比較的數(shù)組項作為參數(shù)傳遞給這個函數(shù)。當(dāng)函數(shù)返回值為1的時候就交換兩個數(shù)組項的順序,否則就不交換。
    我們可以對上面的randomsort()稍作修改,來實現(xiàn)升序排列和降序排列:
    function asc(a,b) {
    return a < b ? -1 : 1;//如果a<b不交換,否則交換,即升序排列
    }
    function desc(a,b) {
    return a > b ? -1 : 1;;//如果a>b不交換,否則交換,即將序排列
    }
    另外,可以直接把一個無名函數(shù)直接放到sort()方法的調(diào)用中。如下的例子是將奇數(shù)排在前面,偶數(shù)排在后面,例子如下:
    以下是引用片段:
    var arrA = [6,2,4,3,5,1];
    arrA.sort( function(x, y) {
    if (x % 2 ==0) return 1;
    if (x % 2 !=0) return -1;
    });
    document.writeln(arrA); //輸出:1,5,3,4,6,2
    希望本文所述對大家JavaScript程序設(shè)計有所幫助。