效果展示
实现原理
1. html:一般就是一个div: <div id="code"></div> ,样式根据需求设计。
2. JS:1)将所有的验证码所用的字符放在一个字符串中
2)在这个字符串的字符个数以内,随机生成索引号
3)根据索引号查找对应字符,拼接成验证码的字符串
代码实现
HTML:
<div id="code"></div>
CSS:
1 * {
2 margin: 0;
3 padding: 0;
4 }
5 div {
6 width: 80px;
7 height: 30px;
8 font-size: 18px;
9 line-height: 30px;
10 text-align: center;
11 color: #333;
12 border: 1px solid red;
13 margin: 100px auto;
14 cursor: pointer;
15 }
JavaScript:
1 var codeStr = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
2 var oDiv = document.getElementById('code');
3 // 用来生成随机整数
4 function getRandom(n, m) { // param: (Number, Number)
5 n = Number(n);
6 m = Number(m);
7 // 确保 m 始终大于 n
8 if (n > m) {
9 var temp = n;
10 n = m;
11 m = temp;
12 }
13 // 下有详细说明
14 return Math.floor(Math.random()*(m - n) + n);
15 }
16 // 将随机生成的整数下标对应的字母放入div中
17 function getCode() {
18 var str = '';
19 // 验证码有几位就循环几次
20 for (var i = 0;i < 4;i ++) {
21 var ran = getRandom(0, 62);
22 str += codeStr.charAt(ran);
23 }
24 oDiv.innerHTML = str;
25 }
26 getCode();// 调用函数,页面刷新也会刷新验证码
27 // 点击刷新验证码
28 oDiv.onclick = function(){
29 getCode();
30 }
代码分析
JS:1)将所有的验证码所用的字符放在一个字符串中
-- > 代码第1行,除了字母数字也可放入中文汉字等。
2)在这个字符串的字符个数以内,随机生成索引号
-- > 第4行的函数用于生成随机整数,参数 (n, m)为数字,Number()确保是数字
默认m > n,防止传参有误,用if判断后改正
Math.random() -- > [0,1)
Math.random() * (m - n) -- > [0, m - n)
Math.random() * (m - n) + n -- > [n, m)
为了能将codeStr所有的下标都取到,上述m若是codeStr.length,想要取值能取到最后一位,再使用Math.floor()向下取整。
n 为 0,m 为 codeStr.length 则随机范围为codeStr的所有元素下标。例(n, m) -- > (0, 62)计算后的取值范围:下标为[0, 61]的整数。
3)根据下标查找对应元素,拼接成验证码的字符串
第17行的函数getCode()获取字符串中对应元素,并拼接成字符串返回到页面中。最后点击div可不断生成随机验证码。
完整代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>随机生成验证码</title>
<style>
* {
margin: 0;
padding: 0;
}
div {
width: 80px;
height: 30px;
font-size: 18px;
line-height: 30px;
text-align: center;
color: #333;
border: 1px solid red;
margin: 100px auto;
cursor: pointer;
}
</style>
</head>
<body>
<div id="code"></div>
<script>
var codeStr = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
var oDiv = document.getElementById('code');
// 用来生成随机整数
function getRandom(n, m) { // param: (Number, Number)
n = Number(n);
m = Number(m);
// 确保 m 始终大于 n
if (n > m) {
var temp = n;
n = m;
m = temp;
}
return Math.floor(Math.random()*(m - n) + n);
}
// 将随机生成的整数下标对应的字母放入div中
function getCode() {
var str = '';
// 验证码有几位就循环几次
for (var i = 0;i < 4;i ++) {
var ran = getRandom(0, 62);
str += codeStr.charAt(ran);
}
oDiv.innerHTML = str;
}
getCode();// 调用函数,页面刷新也会刷新验证码
// 点击刷新验证码
oDiv.onclick = function(){
getCode();
}
</script>
</body>
</html>
如果有想学习web前端的程序员,加VX:TZ07900, 免费送web前端视频教程噢