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