成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

JavaScript實(shí)現(xiàn)頁面動(dòng)態(tài)驗(yàn)證碼的實(shí)現(xiàn)示例

瀏覽:189日期:2023-10-03 13:37:38
引言:

現(xiàn)在很多在用戶登陸或注冊(cè)的時(shí)候?yàn)榱朔乐钩绦蚬簦尤肓藙?dòng)態(tài)驗(yàn)證的技術(shù),一般是讓用戶輸入隨即生成的驗(yàn)證碼來實(shí)現(xiàn)。我自己寫了一個(gè)沒有跟后臺(tái)交互的,就在前端驗(yàn)證,發(fā)出來給大家看看。

效果圖:

JavaScript實(shí)現(xiàn)頁面動(dòng)態(tài)驗(yàn)證碼的實(shí)現(xiàn)示例

實(shí)現(xiàn)思路: 把數(shù)字和字母放到一個(gè)數(shù)組中,通過隨機(jī)的方式取得數(shù)組下標(biāo),總共取4個(gè)組成驗(yàn)證碼; 把驗(yàn)證碼渲染出來(一個(gè)一個(gè)的渲染); 繪制一定數(shù)量的干擾線,隨機(jī)顏色; 輸入驗(yàn)證碼,輸入4位以后去驗(yàn)證,正確顯示鉤,錯(cuò)誤顯示叉并且刷新驗(yàn)證碼。編寫構(gòu)造函數(shù)

文本構(gòu)造函數(shù)

//文字的構(gòu)造函數(shù)function Text(o){this.x=0,//x坐標(biāo)this.y=0,//y坐標(biāo)this.text=’’,//內(nèi)容this.font=null;//字體this.textAlign=null;//對(duì)齊方式this.init(o);}Text.prototype.init=function(o){for(var key in o){this[key]=o[key];}}Text.prototype.render=function(context){this.ctx=context;innerRender(this);function innerRender(obj){var ctx=obj.ctx;ctx.save()ctx.beginPath();ctx.translate(obj.x,obj.y);if(obj.font){ctx.font=obj.font;}if(obj.textAlign){ctx.textAlign=obj.textAlign;}if(obj.fill){//是否填充obj.fillStyle?(ctx.fillStyle=obj.fillStyle):null;ctx.fillText(obj.text,0,0);} ctx.restore();} return this;}

線段構(gòu)造函數(shù)

//直線的構(gòu)造function Line(ctx,o){this.x=0,//x坐標(biāo)this.y=0,//y坐標(biāo)this.startX=0,//開始點(diǎn)x位置this.startY=0, //開始點(diǎn)y位置this.endX=0,//結(jié)束點(diǎn)x位置this.endY=0;//結(jié)束點(diǎn)y位置this.thin=false;//設(shè)置變細(xì)系數(shù)this.ctx=ctx;this.init(o);}Line.prototype.init=function(o){for(var key in o){this[key]=o[key];}}Line.prototype.render=function(){innerRender(this);function innerRender(obj){var ctx=obj.ctx;ctx.save()ctx.beginPath();ctx.translate(obj.x,obj.y);if(obj.thin){ctx.translate(0.5,0.5);}if(obj.lineWidth){//設(shè)定線寬ctx.lineWidth=obj.lineWidth;}if(obj.strokeStyle){ctx.strokeStyle=obj.strokeStyle;}//劃線 ctx.moveTo(obj.startX, obj.startY); ctx.lineTo(obj.endX, obj.endY); ctx.stroke(); ctx.restore();} return this;}

按長度獲取驗(yàn)證碼

//根據(jù)指定長度生成隨機(jī)字母數(shù)字Verifiable.prototype.randomWord=function(range){ var str = '',pos, arr = [’0’, ’1’, ’2’, ’3’, ’4’, ’5’, ’6’, ’7’, ’8’, ’9’, ’a’, ’b’, ’c’, ’d’, ’e’, ’f’, ’g’, ’h’, ’i’, ’j’, ’k’, ’l’, ’m’, ’n’, ’o’, ’p’, ’q’, ’r’, ’s’, ’t’, ’u’, ’v’, ’w’, ’x’, ’y’, ’z’, ’A’, ’B’, ’C’, ’D’, ’E’, ’F’, ’G’, ’H’, ’I’, ’J’, ’K’, ’L’, ’M’, ’N’, ’O’, ’P’, ’Q’, ’R’, ’S’, ’T’, ’U’, ’V’, ’W’, ’X’, ’Y’, ’Z’]; for(var i=0; i<range; i++){ pos = Math.round(Math.random() * (arr.length-1)); str += arr[pos]; } return str;}

繪制文字

//繪制文字Verifiable.prototype.drawText=function(){var that=this;var count = 4;//文字個(gè)數(shù)var textW = 40;//文字所占寬var code=this.code = this.randomWord(count);var codeArr = code.split('');var text,x ;codeArr.forEach(function(c,i){x = that.w/count*i+textW/2;//繪制文字text = new Text({x:x,y:textW-10,text:c,font:’30px ans-serif’,textAlign:’center’,fill:true,fillStyle:’#412D6A’});that.renderArr.push(text);})}

此時(shí)效果:

JavaScript實(shí)現(xiàn)頁面動(dòng)態(tài)驗(yàn)證碼的實(shí)現(xiàn)示例

繪制干擾線

//繪制干擾線Verifiable.prototype.interfering=function(){var count = this.lineCount=20,line,ctx=this.ctx;var startX,startY,endX,endY,color;for(var i=0;i<count;i++){//隨機(jī)開始坐標(biāo),結(jié)束坐標(biāo)、顏色startX = _.getRandom(0,140);startY = _.getRandom(0,40);endX = _.getRandom(0,140);endY = _.getRandom(0,40);color = _.getRandomColor();//定義一條直線line = new Line(ctx,{x:0,y:0, startX:startX, startY:startY, endX:endX, endY:endY, strokeStyle:color})this.renderArr.push(line);}}

此時(shí)效果如下:

JavaScript實(shí)現(xiàn)頁面動(dòng)態(tài)驗(yàn)證碼的實(shí)現(xiàn)示例

加入頁面布局

<!DOCTYPE html><html lang='zh'> <head> <meta charset='UTF-8'> <title>verifiable</title> <style> #box{width:140px;height:40px;position:absolute;}#inputDiv{width:220px;position:absolute;margin:0 auto;left:0;top:30px;right:0;bottom:0;}#container{width:220px;height:60px;position:absolute;margin:0 auto;left:0;top:60px;right:0;bottom:0;}.refresh{position:absolute;left:140px;} </style></head> <body><div id=’inputDiv’> 驗(yàn)證碼:<input size=10 id=’codeInput’><img id=’stateImg’ style='vertical-align: middle;width:20px'></img> </div> <div id='container'> <div id=’box’></div> <a href='javascript:void 0' onclick='refresh()'>換一張</a> </div></body><script type='text/javascript' src=’verifiable.js’></script> <script type='text/javascript'> var box = document.getElementById(’box’); var stateImg = document.getElementById(’stateImg’); var codeInput = document.getElementById(’codeInput’); verifiable.init(box,codeInput,stateImg);//換一張function refresh(){verifiable.renderArr.length=0;verifiable.draw();} </script></html>

加入輸入框事件

//輸入框事件Verifiable.prototype.inputValid=function(input){var val = input.value;if(val.length<4) return ;if(this.code==val){console.log(’suc’);this.result(0);}else{this.result(1);}}

加入成功、失敗驗(yàn)證

//處理結(jié)果Verifiable.prototype.result=function(result){var codeInput = this.codeInput;var stateImg = this.stateImg;if(result==0){//成功stateImg.src='http://www.piao2010.com/bcjs/images/suc.jpeg';codeInput.readOnly=true;}else {//失敗codeInput.readOnly=false;stateImg.src='http://www.piao2010.com/bcjs/images/fail.jpeg';this.renderArr.length=0;this.draw();}}

完成

JavaScript實(shí)現(xiàn)頁面動(dòng)態(tài)驗(yàn)證碼的實(shí)現(xiàn)示例

代碼下載

到此這篇關(guān)于JavaScript實(shí)現(xiàn)頁面動(dòng)態(tài)驗(yàn)證碼的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)JavaScript 動(dòng)態(tài)驗(yàn)證碼內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
91免费观看视频在线| 99re这里都是精品| 懂色av一区二区在线播放| 亚洲欧美大片| 中文一区二区在线观看| 国产suv精品一区二区6| 91国产成人在线| 亚洲国产中文字幕在线视频综合| 国产主播一区| 久久久精品2019中文字幕之3| 丰满少妇久久久久久久| 欧美精品精品一区| 久久狠狠亚洲综合| 在线一区二区三区四区| 亚洲免费在线观看视频| 黄色欧美成人| 中文字幕免费在线观看视频一区| 99久久伊人精品| 欧美zozozo| av电影在线观看不卡| 日韩三级精品电影久久久| 久久超碰97中文字幕| 欧美在线你懂的| 日韩国产欧美三级| 看欧美日韩国产| 日韩va亚洲va欧美va久久| 久久精品人人做人人爽电影蜜月| 午夜伦理一区二区| 小嫩嫩精品导航| 亚洲国产成人tv| 免费视频一区二区三区在线观看| 亚洲成人av电影在线| 久久久久久久高潮| 亚洲成a人v欧美综合天堂下载| 久久福利电影| 视频一区欧美日韩| 一本大道久久精品懂色aⅴ| 日韩精品久久久久久| 91成人在线观看喷潮| 久久精品国产一区二区| 欧美挠脚心视频网站| 国产剧情一区在线| 欧美电影免费观看高清完整版在线观看| 岛国av在线一区| 欧美第一区第二区| aaa亚洲精品| 中文在线免费一区三区高中清不卡| 伊人久久综合| 亚洲一区二三区| 91黄视频在线观看| 九色porny丨国产精品| 51精品秘密在线观看| 成人午夜在线播放| 2020国产精品| 91网站视频在线观看| 国产精品久线在线观看| 宅男噜噜噜66一区二区| 亚洲大型综合色站| 日本道色综合久久| 国内久久精品视频| 2020国产精品| 99国产精品久久久久老师| 亚洲成人激情av| 欧美精三区欧美精三区| 91在线porny国产在线看| 国产精品久久福利| 美女被久久久| 国产精品一二三| 国产三级精品三级| 国产精品免费看| 国产在线不卡一区| 国产亚洲精品中文字幕| 国产精品欧美日韩一区| 激情综合一区二区三区| 精品成人一区二区| 亚洲免费激情| 久久精品久久精品| 久久精品男人天堂av| 国产精品久久波多野结衣| 精品一区二区三区免费视频| 国产人成一区二区三区影院| 久久国产精品一区二区三区| 国产福利一区二区| 成人免费视频在线观看| 欧美亚洲动漫精品| 97久久精品人人做人人爽| 亚洲一级二级在线| 日韩午夜av电影| 精品不卡视频| 麻豆高清免费国产一区| 久久精品免视看| 久色成人在线| 91影视在线播放| 丝袜亚洲另类欧美| 久久伊99综合婷婷久久伊| 麻豆精品网站| 91视视频在线直接观看在线看网页在线看| 亚洲一卡二卡三卡四卡无卡久久| 精品欧美乱码久久久久久1区2区 | 亚洲欧美乱综合| 91精品视频网| 国产精品乱看| 不卡的av在线播放| 亚洲国产精品麻豆| 国产午夜精品久久久久久久 | 久久综合一区二区三区| 色综合久久综合中文综合网| 日韩在线播放一区二区| 久久久久久久久久美女| 日本韩国欧美一区二区三区| 欧美三区视频| 国产精品主播直播| 亚洲精品成人a在线观看| 日韩色视频在线观看| 久久精品天堂| 欧美日韩三区| 国产精品2024| 日韩专区中文字幕一区二区| 国产精品国产三级国产普通话三级 | 成人黄色在线看| 五月天国产精品| 国产免费观看久久| 欧美一区二区三区免费| 麻豆精品91| 一区一区视频| 成人免费毛片aaaaa**| 五月天激情综合网| 国产精品久久久久久福利一牛影视 | 亚洲午夜精品一区二区| 国产精品资源网| 免费观看30秒视频久久| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 日韩一区二区精品| 色国产综合视频| 国产偷国产偷亚洲高清97cao| 欧美成人在线免费观看| 国产精品综合网| 青青青爽久久午夜综合久久午夜| 亚洲乱码日产精品bd| 中文字幕巨乱亚洲| 精品欧美一区二区久久 | 中文字幕中文字幕一区| 日韩精品一区二| 欧美日韩三级一区| 玖玖玖国产精品| 国产精品久久国产愉拍| 黑人中文字幕一区二区三区 | 欧美区日韩区| 99国产精品久久久| 国产成人午夜精品影院观看视频| 青青草国产精品亚洲专区无| 亚洲一区二区三区四区五区中文| 国产精品丝袜一区| 精品粉嫩aⅴ一区二区三区四区| 在线综合+亚洲+欧美中文字幕| 91电影在线观看| 久久一区视频| 性色av一区二区怡红| 亚洲视频免费| 欧美精品aa| 91美女蜜桃在线| 99久久久国产精品免费蜜臀| 国产夫妻精品视频| 国产一区二区导航在线播放| 九九热在线视频观看这里只有精品| 日本亚洲欧美天堂免费| 日韩中文字幕av电影| 天天影视涩香欲综合网| 亚洲国产另类精品专区| 一区二区三区在线观看欧美| 亚洲嫩草精品久久| 亚洲免费av高清| 一区二区三区欧美在线观看| 亚洲天堂网中文字| 国产精品进线69影院| 国产精品国产三级国产aⅴ原创| 中文字幕欧美三区| 国产精品乱人伦一区二区| 专区另类欧美日韩| 亚洲精品五月天| 一区二区三区国产精华| 一区二区高清在线| 亚洲一区二区三区不卡国产欧美| 亚洲一区二区三区影院| 亚洲一卡二卡三卡四卡无卡久久| 亚洲国产成人精品视频| 丝袜诱惑亚洲看片| 麻豆精品新av中文字幕| 久久国产生活片100| 狠狠久久亚洲欧美| 福利91精品一区二区三区| 成人黄色一级视频| 色综合天天综合网天天狠天天| 午夜久久黄色| 亚洲国产高清一区| 亚洲影视在线| 色94色欧美sute亚洲线路一ni| 欧美亚洲一区二区在线| 欧美电影一区二区| 精品成人私密视频|