国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

js實現隨機8位驗證碼

來源:懂視網 責編:小采 時間:2020-11-27 21:55:35
文檔

js實現隨機8位驗證碼

js實現隨機8位驗證碼:開發思路: 1.畫出放置驗證碼的模塊、一個寫有看不清…的小塊,以及輸入驗證碼的文本框 2.獲取各個模塊 3.封裝一個函數Yan_ma(),設置驗證碼為8位,里面含有數字,小寫字母,小寫字母和中文。每種類型出現的可能性為25%。 4.隨機數字在0-9,之間。對
推薦度:
導讀js實現隨機8位驗證碼:開發思路: 1.畫出放置驗證碼的模塊、一個寫有看不清…的小塊,以及輸入驗證碼的文本框 2.獲取各個模塊 3.封裝一個函數Yan_ma(),設置驗證碼為8位,里面含有數字,小寫字母,小寫字母和中文。每種類型出現的可能性為25%。 4.隨機數字在0-9,之間。對

開發思路:

1.畫出放置驗證碼的模塊、一個寫有“看不清…”的小塊,以及輸入驗證碼的文本框
2.獲取各個模塊
3.封裝一個函數Yan_ma(),設置驗證碼為8位,里面含有數字,小寫字母,小寫字母和中文。每種類型出現的可能性為25%。
4.隨機數字在0-9,之間。對Math.ramand()向下取整。
5.隨機大小寫字母使用fromCharCode() 方法:將 Unicode 編碼轉為一個字符,例如:

var n = String.fromCharCode(65);
cosole.log(n);
//
輸出j結果為A

大寫字母(65-91) 小寫字母(97-123)

var s = String.fromCharCode(Math.floor(Math.random() * 26 + 65));
var s = String.fromCharCode(Math.floor(Math.random() * 26 + 97));

6.隨機中文,聲明變量letter放置中文字符串,使用charAt()隨機在letter中獲得某個漢字。

var letter = "如若可以親愛的請許我青燈墨下執一筆素箋今生為你吟盡千回百轉念";
var s = letter.charAt(Math.floor(Math.random() * letter.length));

7.給每位驗證碼設隨機的顏色,字體大小,相對文本位置,旋轉角度。給顏色封裝一個函數,使用十六進制顏色(如:#ffffff)

//隨機顏色
 function fontcolor(){
 var s1="";
 for(var k=0;k<6;k++){
 var z=[0,1,2,3,4,5,6,7,8,9,"a","b","c","d","e","f"];
 var m=z[Math.floor(Math.random() * z.length)];
 s1 +=m;
 }
 return "#"+s1;
 }

隨機位置和隨機旋轉角度的方法相同

隨機位置可能為向上下左右偏移 8px, 隨機旋轉角度可能為繞著z軸旋轉(±45度)。

8.提前聲明一個空字符串 str 讓每位驗證碼用字符串連接起來.

var s = String.fromCharCode(Math.floor(Math.random() * 26 + 97));
str+="<span style ='transform:rotatez("+ zhuan +"deg);left:"+topset+"px; color: " +color +" ;font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
 arr+=s;

9.讓8位驗證碼出現在第一個大模塊中的innerHTML中。

10.給寫有“看不清”的span標簽添加點擊事件,點擊時,調用函數Yan_ma,刷新驗證碼。

11.如果輸入的驗證碼不正確,則彈出“驗證成功”,否則彈出“驗證失敗”。

<!DOCTYPE html>
<html>
<head lang="en">
 <meta charset="UTF-8">
 <title>隨機驗證碼</title>
 <script>
 var arr="";
 window.onload=function() {
 var maa = document.getElementsByClassName("block")[0];
 var looking = document.getElementById("look");
 var put = document.getElementById("text");
 var btnn = document.getElementById("btn");
 Yan_ma(maa);
 looking.onclick=function (){
 Yan_ma(maa);
 };
 btnn.onclick=function(){
 if(put.value.toLowerCase()==arr.toLowerCase()){
 alert ("驗證成功");
 }
 else{
 alert ("驗證失敗");
 Yan_ma(maa);
 }
 }

 };


 function Yan_ma(aim) {
 arr ="";
 var str="";
 for (var i = 0; i < 8; i++) {
 //隨機數 Math.random 0-1 的隨機值
 var n = Math.random();
 //隨機顏色
 var color=fontcolor();
 //隨機大小
 var size=Math.floor (Math.random ()*12 +20);
 //隨機位置
 var g=Math.random() <0.5 ? -1: 1;
 var topset=Math.random ()*g*8;
 //隨機旋轉
 var h=Math.random() <0.5 ? -1: 1;
 var zhuan=Math.random ()*h*45;
 if (n < 0.25) {
 //隨機數字
 var s = Math.floor(Math.random() * 10);
 str+="<span style='transform:rotatez("+ zhuan +"deg);left:"+topset+"px; color: " +color +";font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
 arr+=s;
 }
 //隨機大寫字母 //65-91
 else if (n >= 0.25 && n < 0.5) {
 var s = String.fromCharCode(Math.floor(Math.random() * 26 + 65));
 str+="<span style='transform:rotatez("+ zhuan +"deg); left:"+topset+"px; color: " +color +";font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
 arr+=s;
 }
 //隨機小寫字母 97-123
 else if (n >=0.5 && n < 0.75) {
 var s = String.fromCharCode(Math.floor(Math.random() * 26 + 97));
 str+="<span style ='transform:rotatez("+ zhuan +"deg);left:"+topset+"px; color: " +color +" ;font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
 arr+=s;
 }
 //隨機文字
 else {
 var letter = "如若可以親愛的請許我青燈墨下執一筆素箋今生為你吟盡千回百轉念";
 var s = letter.charAt(Math.floor(Math.random() * letter.length));
 str+="<span style='transform: rotatez("+ zhuan +" deg) ; left:"+topset+"px; color: " +color +";font-size:"+size+"px;top:"+topset+"px '>"+s+"</span>";
 arr+=s;
 }
 }
 aim.innerHTML =str;
 }

 function fontcolor(){
 var s1="";
 for(var k=0;k<6;k++){
 var z=[0,1,2,3,4,5,6,7,8,9,"a","b","c","d","e","f"];
 var m=z[Math.floor(Math.random() * z.length)];
 s1 +=m;
 }
 return "#"+s1;
 }

 </script>
 <style>
 .block{
 width:250px;
 height:60px;
 background:url("bg2.png") no-repeat center;
 background-size: 100%;
 text-align: center;
 line-height: 60px;
 }
 .block span{
 position: relative;
 display: inline-block;
 width:20px;
 margin:5px 3px;
 }
 #look{
 color: #9200ff;
 }
 #look:hover{
 cursor: pointer;
 }
 </style>
</head>
<body>
<div class="block">
</div>
<span id="look">看不清...</span>
<br/>
<input type="text" id="text" placeholder="請輸入驗證碼" />
<button id="btn">驗證</button>
</body>
</html>

出現的驗證碼

當輸入正確驗證碼時

當沒輸入錯誤驗證碼時

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

js實現隨機8位驗證碼

js實現隨機8位驗證碼:開發思路: 1.畫出放置驗證碼的模塊、一個寫有看不清…的小塊,以及輸入驗證碼的文本框 2.獲取各個模塊 3.封裝一個函數Yan_ma(),設置驗證碼為8位,里面含有數字,小寫字母,小寫字母和中文。每種類型出現的可能性為25%。 4.隨機數字在0-9,之間。對
推薦度:
標簽: 驗證碼 js 隨機
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 91精品国产高清久久久久久91 | 夜夜操综合 | 国产美女视频黄a视频全免费网站 | 国产一区在线视频观看 | 午夜视频在线观看免费视频 | 韩日欧美 | 国产美女精品久久久久中文 | 国内精品伊人久久久影视 | 国产成人综合精品一区 | 亚洲免费网站观看视频 | 在线观看国产精品入口 | 日韩色在线 | 久久国内精品 | 一区在线免费观看 | 成人美女黄网站色大色费 | 成人日韩在线 | 国产精品亚洲精品观看不卡 | 在线 v亚洲 v欧美v 专区 | 日韩 亚洲 制服 欧美 综合 | 日本一区二区三区在线播放 | 精品一区二区在线欧美日韩 | 69视频高清完整版在线观看 | 国产一区二区三区夜色 | 国产高清在线精品一区二区三区 | 欧美在线免费观看视频 | 亚洲国产成人久久综合一 | 国产69久久精品成人看小说 | 毛片一级免费 | 精品一区二区三区免费毛片爱 | 国产精选在线观看 | 欧美日韩中文字幕 | 91国内精品久久久久免费影院 | 一区在线免费观看 | 欧美xxxx性疯狂bbbb | 么公又大又硬又粗又爽的视频 | 久久影院一区 | 久久精品男人影院 | 素人面接 | 精品一区二区视频 | 日本韩国一区 | 黄色毛片免费看 |