JS隨機打亂數(shù)組的方法小結
來源:易賢網(wǎng) 閱讀:976 次 日期:2016-07-12 16:18:42
溫馨提示:易賢網(wǎng)小編為您整理了“JS隨機打亂數(shù)組的方法小結”,方便廣大網(wǎng)友查閱!

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程序設計有所幫助。

更多信息請查看網(wǎng)絡編程
易賢網(wǎng)手機網(wǎng)站地址:JS隨機打亂數(shù)組的方法小結

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網(wǎng)