今天偶然看到的
比如要生成 1-100范圍之內的10個不重復隨機數,代碼就可以這么寫
var arr = []; for (var i = 1; i <=100; i++) { arr.push(i); } arr.sort( function () { return 0.5 - Math.random(); } ); arr.lenth = 10; console.log(
arr
);
下面是w3school對sort()方法的說明
說明
如果調用該方法時沒有使用參數,將按字母順序對數組中的元素進行排序,說得更精確點,是按照字符編碼的順序進行排序。要實現這一點,首先應把數組的元素都轉換成字符串(如有必要),以便進行比較。
如果想按照其他標准進行排序,就需要提供比較函數,該函數要比較兩個值,然后返回一個用於說明這兩個值的相對順序的數字。比較函數應該具有兩個參數 a 和 b,其返回值如下:
- 若 a 小於 b,在排序后的數組中 a 應該出現在 b 之前,則返回一個小於 0 的值。
- 若 a 等於 b,則返回 0。
- 若 a 大於 b,則返回一個大於 0 的值。
我只想說,還是不太明白到底sort()是怎么樣的一個比較流程,希望有人可以給個詳細說明。