JS实现随机生成四位验证码(数字+大小写字母+随机颜色)

html 部分

  <div id="box">
        <span></span>
        <span></span>
        <span></span>
        <span></span>
    </div>
    <button id="btn">生成验证码</button>

css部分

<style>
        #box{
            font-size: 20px;
        }
    </style>

script 部分

    var span = document.getElementsByTagName("span");
    var box = document.getElementById("box");
    var btn = document.getElementById("btn");
    btn.onclick = function () {
        //声明一个strArr数组,存放0-9,26个字母的大小写;
        var strArr = [0,1,2,3,4,5,6,7,8,9];
        for(var i=0;i<26;i++) {
            strArr.push(String.fromCharCode(97+i)); // String.fromCharCode()方法
            strArr.push(String.fromCharCode(65+i)); //fromCharCode() 可接受一个指定的 Unicode 值,然后返回一个字符串。
        }
        console.log(strArr);
        //声明一个newArr数组,数组长度固定为4,随机填入4个strArr数组中的数组元素,并写进每个span标签中
        //昨天写的数组乱序,派上用场了
        var newArr = [];
        for(var j = 0;j < 4; j++){
            var a = Math.floor(Math.random()*strArr.length);
            newArr.push(strArr[a]);
            strArr.splice(a,1);
            span[j].innerHTML = newArr[j];
            span[j].style.color = randomColor();
        }
        //之前写的随机生成颜色的函数完美代入!哈哈哈哈哈哈
        function randomColor() {
            var col = "rgb(";
            for(var i = 0;i < 3;i++){
                col += Math.floor(Math.random()*256)+",";
            }
            col = col.slice(0,-1);//rgb( 会多出一个 , 将它舍弃;
            col += ")"; //加上 ) 得到 rgb(***,***,***);
            return col;
        }
    }
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值