基于js的算术验证

来源:互联网 发布:淘宝鸿星尔克优惠券 编辑:程序博客网 时间:2024/05/19 03:45

今天心血来潮搜索了下验证码的实现方式,仿照网上一个6位字符型的验证码实现了一个100以内算术题式的验证码。代码如下,备用:

[html] view plain copy
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <html xmlns="http://www.w3.org/1999/xhtml">  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
  5. <title>验证码</title>  
  6. <style type="text/css">  
  7. .nocode {  
  8.     width: 100px;  
  9.     height: 25px;  
  10. }  
  11.   
  12. .code {  
  13.     background: url(code_bg.jpg) repeat;  
  14.     color: #ff0000;  
  15.     font-family: Tahoma, Geneva, sans-serif;  
  16.     font-style: italic;  
  17.     font-weight: bold;  
  18.     text-align: center;  
  19.     width: 100px;  
  20.     height: 25px;  
  21.     cursor: pointer;  
  22. }  
  23.   
  24. .input {  
  25.     width: 100px;  
  26. }  
  27. </style>  
  28. <script type="text/javascript" src="jquery.js"></script>  
  29. <script type="text/javascript">  
  30. $(function() {  
  31.     var code = 9999;  
  32.       
  33.     $(".input").focus(function(){  
  34.         $(this).attr("value", "");  
  35.           
  36.         var num1 = Math.floor(Math.random() * 100);  
  37.         var num2 = Math.floor(Math.random() * 100);  
  38.         code = num1 + num2;  
  39.           
  40.         $("#code").html(num1 + "+" + num2 + "=?");  
  41.         if ($("#code").hasClass("nocode")) {  
  42.             $("#code").removeClass("nocode");  
  43.             $("#code").addClass("code");  
  44.         }  
  45.     });  
  46.       
  47.     $("#check").click(function(){  
  48.         if ($(".input").attr("value") == code && code != 9999) {  
  49.             alert("Pass!");  
  50.         } else {  
  51.             alert("Wrong code!");  
  52.         }  
  53.     });  
  54. });  
  55. </script>  
  56. </head>  
  57.   
  58. <body>  
  59. <input type="text" class="input" />  
  60. <div id="code" class="nocode"></div>  
  61. <button id="check">验证</button>  
  62. </body>  
  63. </html> 

效果如下:


上述实现主要还是基于jQuery,其实也可以不用。JavaScript 1.6新添加了一系列函数,其中就包含document.querySelectordocument.querySelectorAll。这两个函数的作用与jQuery的元素选择器如出一辙,即通过传入类似于 ".class" 、 "#id" 等这样的字符串选择符来获取元素;区别在于 querySelector 函数获取的是符合选择符的第一个DOM元素,而 querySelectorAll 函数获取的是符合选择符的DOM元素数组。获取到元素之后,就可以通过相应的事件(如onfocus、onclick等)来操作数据了。

另外,验证码的元素除了用<div>以外,还可能使用<input type="text">,只不过需要对其做一定的处理:如去掉输入框的边框(border: none),设置为只读(readonly)。

最后附上验证码的背景图片 code_bg.jpg :


0 0
原创粉丝点击