js---隨機產生n個不重複的Number類型的數/英文字母

一、隨機產生n個不重複Number類型的數

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <div id="arr"></div>
</body>
<script>
window.onload = function() {
    var arr = document.getElementById('arr')
    function getNum(n) {
        var arrNum =[];
        for(var i=0 ; i<n ; i++){
            var val = Math.floor(Math.random() * 100);
            // 過濾重複方式一
            if(arrNum.indexOf(val) === -1){
                arrNum.push(val)
            }else{
                i--;
            }
            // 過濾重複方式二
            // if(arrNum.includes(val) === false){
            //     arrNum.push(val)
            // }else{
            //     // arrNum.push(val)
            //     i--;
            // }
        }
        return arrNum;
    }
    arr.innerHTML = getNum(5);
    console.log(getNum(5)+'---'+getNum(5).length)
}
</script>
</html>

效果:

二、隨機產生n個不重複英文字母

    //26個英文字母的生成
    var A_Z="";
    for(var i=65;i<91;i++){
        A_Z+=String.fromCharCode(i)+",";
    }
    var A_Z_Arr = A_Z.split(',')
    function getLetter(n) {
        var letterArr = []
        for(var i=0 ; i<n ; i++){
        var val = Math.floor(Math.random() * 26);
            if(letterArr.includes(val) === false) {
                letterArr.push(A_Z_Arr[val])
            }else{
                i--;
            }
        }
        return letterArr;
    }
    console.log(getLetter(6))

效果:

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章