前端學習程式碼例項-JavaScript 生成隨機數
分享一段非常強大的隨機數生成功能程式碼例項,有需要的朋友可以做一下參考。
程式碼例項如下:
(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前端開發學習扣qun:731771211 詳細教程分享
上面的程式碼實現了獲取隨機數的效果,下面介紹一下它的實現過程。
一.程式碼註釋:
(1).(function(){})(),一個自執行的匿名函式。
(2).var charCodeIndex = [[48,57],[65,90],[97,122]],三個子數字分別表示ascii字元的區間,表示數字、大小寫字母,感興趣的朋友可以自己查閱ascii編碼表,這裡不多介紹。
(3).var charCodeArr = [],次數字用來儲存ascii碼。
(4).function getBetweenRound(min,max){
return Math.floor(min+Math.random()*(max-min));
},此方法實現了獲取min到max之間數字的效果。
(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); } }
}透過迴圈的方式將ascii碼寫入陣列中。
(6).function ranStr(slen){},次函式實現了產生隨機數的效果,參數列示隨機數的長度。
(7).slen = slen || 20,如果沒有規定引數,那麼預設隨機數的長度是20。
(8).charCodeArr.length<62 && getCharCode(),判斷陣列是否已經存入ascii碼,如果沒有就執行函式存入,這個也能夠防止,連續執行ranStr函式導致多次重複給數字壓入ascii碼效果。
(9).var res = [],此陣列用來儲存隨機數結果的。
(10).for(var i=0;i<slen;i++){
var index = getBetweenRound(0,61);
res.push(String.fromCharCode(charCodeArr[index]));
},透過for迴圈獲取隨機數,其實也就是隨機從陣列中取元素。
(11).return res.join(''),將陣列中的元素連線起來。
(12).this.ranStr = ranStr,將隨機數賦值給this.ranStr。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69901074/viewspace-2643021/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 前端學習程式碼例項-JavaScript阻止事件冒泡前端JavaScript事件
- JavaScript 生成隨機數JavaScript隨機
- 前端學習程式碼例項-JavaScript 阻止擊超連結的跳轉前端JavaScript
- JavaScript取餘數程式碼例項JavaScript
- JavaScript倒數計時程式碼例項JavaScript
- JavaScript隨滑鼠晃動的div塊程式碼例項JavaScript
- 例項複習機器學習數學 - 2. 幾種典型離散隨機變數分佈機器學習隨機變數
- JavaScript in運算子程式碼例項JavaScript
- java_隨機數(統計例項)Java隨機
- Django登入(含隨機生成圖片驗證碼)註冊例項Django隨機
- JavaScript 阻止事件冒泡程式碼例項JavaScript事件
- JavaScript運動框架程式碼例項JavaScript框架
- 微信小程式生成隨機數微信小程式隨機
- JavaScript 表單驗證程式碼例項JavaScript
- JavaScript陣列合並程式碼例項JavaScript陣列
- 好程式設計師web前端分享在HTML中使用JavaScript例項程式碼程式設計師Web前端HTMLJavaScript
- python生成隨機數、隨機字串Python隨機字串
- 機器學習 - 似然函式:概念、應用與程式碼例項機器學習函式
- JavaScript中常用的事件程式碼及例項JavaScript事件
- JavaScript刪除元素節點程式碼例項JavaScript
- JavaScript生成隨機顏色值JavaScript隨機
- JavaScript隨機五位數驗證碼JavaScript隨機
- Linux Shell 生成隨機數和隨機字串Linux隨機字串
- vue 原始碼學習 - 例項掛載Vue原始碼
- C++學習隨筆——簡單的單例設計模式例項C++單例設計模式
- C++生成隨機數C++隨機
- java隨機數生成原理Java隨機
- 隨機數生成器隨機
- matlab 生成隨機數序列Matlab隨機
- 結合例項學習|字元編碼和解碼字元
- app直播原始碼,uniapp隨機數生成簽名APP原始碼隨機
- JavaScript隨機輸出大小寫字母程式碼JavaScript隨機
- Makefile例項學習
- JS生成隨機密碼JS隨機密碼
- Linux 生成隨機密碼Linux隨機密碼
- JavaScript讀取文字檔案內容程式碼例項JavaScript
- Matlab 隨機生成兩個數值之間的隨機數Matlab隨機
- canvas繪製機器貓程式碼例項Canvas