首頁  >  文章  >  web前端  >  如何用JavaScript實作取得驗證碼的效果

如何用JavaScript實作取得驗證碼的效果

yulia
yulia原創
2018-10-17 10:33:139485瀏覽

小朋友在瀏覽網站時有沒有發現,幾乎每個網站在登入時,都需要驗證碼驗證,那你知道如何用JS實作取得驗證碼的效果嗎?這篇文章就跟大家聊聊怎麼用JS寫驗證碼,並分享JS取得驗證碼的程式碼,有一定的參考價值,有興趣的朋友可以參考一下。

想用JS實作取得驗證碼,需要用到很多JavaScript中的知識,例如:random(),if函數,for循環等等,如有不清楚的小夥伴可以參考PHP中文網的相關文章,或訪問JavaScript影片教學

自己用JS寫的一個取得驗證碼的簡單程式碼(只是簡單設定了CSS樣式,重點看JavaScript部分啊),具體程式碼如下:

HTML部分:

<body onload=&#39;createCode()&#39;> 
        <div>验证码:  
            <input type = "text" id = "input"/>  
            <input type="button" id="code" onclick="createCode()" style="width:60px" title=&#39;点击更换验证码&#39; /></br>
            <input type = "button" value = "验证" onclick = "validate()"/>
        </div>  
</body>

CSS部分:

 #code{
             font-family:Arial,宋体;
             font-style:italic;
             color:green;
             border:0;
             padding:5px 10px;
             letter-spacing:3px;
             font-weight:bolder;
         }

JavaScript部分:

var code ; //在全局定义验证码         
        function createCode(){
             code = "";   
             var codeLength = 4;//验证码的长度  
             var checkCode = document.getElementById("code");   
             var random = new Array(0,1,2,3,4,5,6,7,8,9,&#39;A&#39;,&#39;B&#39;,&#39;C&#39;,&#39;D&#39;,&#39;E&#39;,&#39;F&#39;,&#39;G&#39;,
             &#39;H&#39;,&#39;I&#39;,&#39;J&#39;,&#39;K&#39;,&#39;L&#39;,&#39;M&#39;,&#39;N&#39;,&#39;O&#39;,&#39;P&#39;,&#39;Q&#39;,&#39;R&#39;,&#39;S&#39;,&#39;T&#39;,&#39;U&#39;,&#39;V&#39;,&#39;W&#39;,&#39;X&#39;,&#39;Y&#39;,
             &#39;Z&#39;);//随机数  
             for(var i = 0; i < codeLength; i++) {//循环操作  
                var index = Math.floor(Math.random()*36);//取得随机数的索引(0~35)  
                code += random[index];//根据索引取得随机数加到code上  
            }  
            checkCode.value = code;//把code值赋给验证码  
        }
        //校验验证码  
        function validate(){  
            var inputCode = document.getElementById("input").value.toUpperCase(); 
            //取得输入的验证码并转化为大写        
            if(inputCode.length <= 0) { //若输入的验证码长度为0  
                alert("请输入验证码!"); //则弹出请输入验证码  
            }else if(inputCode != code ) { //若输入的验证码与产生的验证码不一致时  
                alert("验证码输入错误!"); //则弹出验证码输入错误  
                createCode();//刷新验证码  
                document.getElementById("input").value = "";//清空文本框  
            }else { //输入正确时  
                alert("验证通过");
            }
        }

JavaScript實作取得驗證碼的具體步驟在程式碼註解中已做詳細解釋,這裡不重複了,驗證碼效果如下圖:

如何用JavaScript實作取得驗證碼的效果

以上詳細介紹了JS實作取得驗證碼程式碼的具體步驟,專案中用的比較多,也希望大家可以自己動手嘗試,看看自己能不能寫出這樣的效果,希望這篇文章對你有幫助!

【相關教學推薦】

1. JavaScript中文參考手冊
2. JavaScript圖文教學
3. bootstrap教程

以上是如何用JavaScript實作取得驗證碼的效果的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn