您好,登錄后才能下訂單哦!
JavaScript中怎么生成隨機數(shù),針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
代碼實例如下:
(function(){ var charCodeIndex = [[48,57],[65,90],[97,122]]; var charCodeArr = []; function getBetweenRound(min,max){ return Math.floor(min+Math.random()*(max-min)); }; function getCharCode(){ for(var index=0,len=3;index<len;index++){ var thisArr = charCodeIndex[index]; for(var j=thisArr[0],thisLen=thisArr[1];j<=thisLen;j++){ charCodeArr.push(j); } } } function ranStr(slen){ slen = slen || 20; charCodeArr.length<62 && getCharCode(); var res = []; for(var i=0;i<slen;i++){ var index = getBetweenRound(0,61); res.push(String.fromCharCode(charCodeArr[index])); } return res.join(''); }; this.ranStr = ranStr; })(); console.log(this.ranStr(4)); web前端開發(fā)學習扣qun:731771211 詳細教程分享
上面的代碼實現(xiàn)了獲取隨機數(shù)的效果,下面介紹一下它的實現(xiàn)過程。
一.代碼注釋:
(1).(function(){})(),一個自執(zhí)行的匿名函數(shù)。
(2).var charCodeIndex = [[48,57],[65,90],[97,122]],三個子數(shù)字分別表示ascii字符的區(qū)間,表示數(shù)字、大小寫字母,感興趣的朋友可以自己查閱ascii編碼表,這里不多介紹。
(3).var charCodeArr = [],次數(shù)字用來存儲ascii碼。
(4).function getBetweenRound(min,max){
return Math.floor(min+Math.random()*(max-min));
},此方法實現(xiàn)了獲取min到max之間數(shù)字的效果。
(5).function getCharCode(){
for(var index=0,len=3;index<len;index++){ var thisArr = charCodeIndex[index]; for(var j=thisArr[0],thisLen=thisArr[1];j<=thisLen;j++){ charCodeArr.push(j); } }
}通過循環(huán)的方式將ascii碼寫入數(shù)組中。
(6).function ranStr(slen){},次函數(shù)實現(xiàn)了產(chǎn)生隨機數(shù)的效果,參數(shù)表示隨機數(shù)的長度。
(7).slen = slen || 20,如果沒有規(guī)定參數(shù),那么默認隨機數(shù)的長度是20。
(8).charCodeArr.length<62 && getCharCode(),判斷數(shù)組是否已經(jīng)存入ascii碼,如果沒有就執(zhí)行函數(shù)存入,這個也能夠防止,連續(xù)執(zhí)行ranStr函數(shù)導致多次重復給數(shù)字壓入ascii碼效果。
(9).var res = [],此數(shù)組用來存儲隨機數(shù)結果的。
(10).for(var i=0;i<slen;i++){
var index = getBetweenRound(0,61);
res.push(String.fromCharCode(charCodeArr[index]));
},通過for循環(huán)獲取隨機數(shù),其實也就是隨機從數(shù)組中取元素。
(11).return res.join(''),將數(shù)組中的元素連接起來。
(12).this.ranStr = ranStr,將隨機數(shù)賦值給this.ranStr。
關于JavaScript中怎么生成隨機數(shù)問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業(yè)資訊頻道了解更多相關知識。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。