js实现网页验证码功能

html部分代码:
  
  
  1. <html>
  2. <head>
  3. <script language = "javascript" src = "code.js"></script>
  4. <link rel="stylesheet" type="text/css" href="code.css">
  5. </head>
  6. <body onload="createCode();">
  7. <form>
  8. <center>验证码:<input type="text" id="input1" />
  9. <input type="text" id="checkCode" class="code" style="width: 55px" /> <a href="#" onclick="createCode()">换一张</a>
  10. <input id="Button1" onclick="validate();" type="button" value="确定" /></center>
  11. </form>
  12. </body>
  13. </html>
css部分代码:
  
  
  1. .code{
  2. background-image:url(w1.jpg);
  3. font-family:Arial;
  4. font-style:italic;
  5. color:Red;
  6. border:0;
  7. padding:2px 3px;
  8. letter-spacing:3px;
  9. font-weight:bolder;
  10. }
js部分代码(包含验证):
  
  
  1. var code ; //在全局 定义验证码
  2. function createCode(){  
  3. code = "";
  4. var codeLength = 4;//验证码的长度
  5. var checkCode = document.getElementById("checkCode");
  6. checkCode.value = "";
  7. var selectChar = new Array(1,2,3,4,5,6,7,8,9,'a','b','c','d','e','f','g','h','j','k','l','m','n','p','q','r','s','t','u','v','w','x','y','z','A','B','C','D','E','F','G','H','J','K','L','M','N','P','Q','R','S','T','U','V','W','X','Y','Z');
  8. for(var i=0;i<codeLength;i++) {
  9. var charIndex = Math.floor(Math.random()*60);
  10. code +=selectChar[charIndex];
  11. }
  12. if(code.length != codeLength){
  13. createCode();
  14. }
  15. checkCode.value = code;
  16. }
  17. function validate () {
  18. var inputCode = document.getElementById("input1").value.toUpperCase();
  19. var codeToUp=code.toUpperCase();
  20. if(inputCode.length <=0) {
  21. alert("请输入验证码!");
  22. return false;
  23. }
  24. else if(inputCode != codeToUp ){
  25. alert("验证码输入错误!");
  26. createCode();
  27. return false;
  28. }
  29. else {
  30. alert("输入正确,输入的验证码为:"+inputCode);
  31. return true;
  32. }
  33. }

注意:①需要在body中加上:onload="createCode();",否则第一次无法加载出验证码;
           ②Math.random()  生成0和1之间的随机小数
               Math.random() * 7 生成0和7之间的随机小数
               Math.random() * 7 + 1生成0和8之间的随机小数
               Math.floor(Math.random() * 7 + 1)生成0和8之间的随机整数,注意是整数,不是小数;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值