這次帶給大家JS隨機生成數與序列方法詳解,JS隨機生成數與序列的注意事項有哪些,以下就是實戰案例,一起來看一下。
•1.Math.random(); 結果為0-1間的一個隨機數(包括0,不包括1)
•2.Math.floor(num); 參數num為數值,函數結果為num的整數部分。與取整數的parseInt(num)方法一樣。
•3.Math.round(num); 參數num為一個數值,函數結果為num四捨五入後的整數。
•4.Math.ceil(num); 傳回大於等於n的最小整數。
合理地使用上述方法產生指定範圍的隨機數:
包含最小值不包含最大值的情況:
parseInt(num)取整,將傳入的num轉化為小的整數。將Math.random()乘以最大和最小的差值,在用parseInt處理(注意此時的範圍是【0-差值)),再加上最小值,就能得到包括最小值但不包括最大值的整數。
取得包含最小值但不包含最大值的隨機數,以下列函數實作:
function getRandom1(start, end) { var length = end - start; var num = parseInt(Math.random() * (length) + start); return num; }
包含最大值但不包含最小值的情況:
Math.ceil(num)
取得大於等於num的最小整數,也就是將傳入的num轉換成大的整數。將Math.random()乘以最大和最小的差值,在用Math.ceil()處理(注意此時的範圍是(0-差值】),在加上最小值,就能得到不包括最小值但包括最大值的整數。
function getRandom1(start, end) { var length = end - start; var num = Math.ceil(Math.random() * (length) + start); return num; }--------------------- -------------------------------------------------- --------- 一些時候,僅僅產生隨機數是不夠的,還需要將指定範圍的數值,按照隨機順序排列。數組並避免重複的問題。序列: 隨機序列可直接透過sort排序方法實現,將一個包含一組按順序排列的數字元素,調用sort方法,透過函數傳入隨機產生的值(可能為正可能為負) ,就可以將順序打亂,得到該數組的隨機序列。 :
function getRandom1(start, end) { var length = end - start + 1; var num = parseInt(Math.random() * (length) + end); return num; }自己寫邏輯生成隨機序列也是可行的: 定義存儲隨機數的數組,然後循環生成隨機數,生成之後到已有數組中查找,如果存在,將標記變成false表示產生的隨機數重複,根據標記值決定是否加入陣列。 。 ! ##
以上是JS隨機產生數與序列法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!