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