JS中,要打亂數(shù)組有很多方法,網(wǎng)上流傳一個國外人寫的方法,我認為是最精簡的了:
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 對象進行適當?shù)呐判颍辉趫?zhí)行過程中并不會創(chuàng)建新的 Array 對象。
sortFunction為可選項。
是用來確定元素順序的函數(shù)的名稱。如果這個參數(shù)被省略,那么元素將按照 ASCII 字符順序進行升序排列。
sortFunction方法有兩個參數(shù)。分別代表每次排序比較時的兩個數(shù)組項。sort()排序時每次比較兩個數(shù)組項都回執(zhí)行這個參數(shù),并把兩個比較的數(shù)組項作為參數(shù)傳遞給這個函數(shù)。當函數(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程序設計有所幫助。