DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JS實現的生成隨機數的4個函數分享
JS實現的生成隨機數的4個函數分享
編輯:關於JavaScript     

第一種方法
代碼如下:
/*
*@desc:生成隨機字符串
*@remark:toString方法可以接收一個基數作為參數的原理,這個基數從2到36封頂。如果不指定,默認基數是10進制
*/
function generateRandomAlphaNum(len) {
    var rdmString = "";
    for (; rdmString.length < len; rdmString += Math.random().toString(36).substr(2));
    return rdmString.substr(0, len);
}

第二種方法

代碼如下:
//JS生成GUID函數,類似.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函數,類似.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(){
    //數字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;
})();

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved