[js][技巧]生成指定範圍指定個數的不重複隨機數

今天偶然看到的

比如要生成 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);

以下代碼補充與2017年11月20日
今天突然翻看以前的博客,發現自己的代碼可以改進一下。

var array = new Array(100)
    .fill(0)
    .map((v,i)=>i+1)
    .sort(()=>0.5 - Math.random())
    .filter((v,i)=>i<10);
console.log(array);// [21, 93, 4, 61, 70, 63, 80, 85, 69, 31]

下面是w3school對sort()方法的說明
JavaScript sort() 方法

說明

如果調用該方法時沒有使用參數,將按字母順序對數組中的元素進行排序,說得更精確點,是按照字符編碼的順序進行排序。要實現這一點,首先應把數組的元素都轉換成字符串(如有必要),以便進行比較。

如果想按照其他標準進行排序,就需要提供比較函數,該函數要比較兩個值,然後返回一個用於說明這兩個值的相對順序的數字。比較函數應該具有兩個參數 a 和 b,其返回值如下:

  • 若 a 小於 b,在排序後的數組中 a 應該出現在 b 之前,則返回一個小於 0 的值。
  • 若 a 等於 b,則返回 0。
  • 若 a 大於 b,則返回一個大於 0 的值。

我只想說,還是不太明白到底sort()是怎麼樣的一個比較流程,希望有人可以給個詳細說明。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章