JS實現(xiàn)的生成隨機數(shù)的4個函數(shù)分享
第一種方法
/*
*@desc:生成隨機字符串
*@remark:toString方法可以接收一個基數(shù)作為參數(shù)的原理,這個基數(shù)從2到36封頂。如果不指定,默認(rèn)基數(shù)是10進制
*/
function generateRandomAlphaNum(len) {
var rdmString = "";
for (; rdmString.length < len; rdmString += Math.random().toString(36).substr(2));
return rdmString.substr(0, len);
}
第二種方法
//JS生成GUID函數(shù),類似.net中的NewID();
function S4() {
return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1);
}
function NewGuid() {
return (S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4());
}
第三種方法
//JS生成GUID函數(shù),類似.net中的NewID();
function newGuid() {
var guid = "";
for (var i = 1; i <= 32; i++) {
var n = Math.floor(Math.random() * 16.0).toString(16);
guid += n;
if ((i == 8) || (i == 12) || (i == 16) || (i == 20))
guid += "-";
}
return guid;
}
第四種方法
/*
*@desc:生成隨機字符串
*@demo:console.log(ranStr());
*/
;(function(){
//數(shù)字0-9,大寫字母,小寫字母,ASCII或UNICODE編碼(十進制),共62個
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 i=0,len=3;i<len;i++){
var thisArr = charCodeIndex[i];
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;
})();
相關(guān)文章
JavaScript高級程序設(shè)計(第3版)學(xué)習(xí)筆記6 初識js對象
砌好墻,下面出場的就是房子了,在ECMAScript中,對象就是我們所說的房子,至于你所寫的整個應(yīng)用程序,那就是一整套建筑群了2012-10-10
詳解JavaScript正則表達式中的global屬性的使用
這篇文章主要介紹了詳解JavaScript正則表達式中的global屬性的使用,是JS學(xué)習(xí)進階中的重要知識點,需要的朋友可以參考下2015-06-06
緩動函數(shù)requestAnimationFrame 更好的實現(xiàn)瀏覽器經(jīng)動畫
requestAnimationFrame是什么?一直是我們大家所疑惑的,緩動函數(shù)requestAnimationFrame 更好的實現(xiàn)瀏覽器經(jīng)動畫,接下來將為大家詳細介紹2012-12-12

