JavaScript生成隨機(jī)驗(yàn)證碼代碼實(shí)例
利用canvas制作一個(gè)隨機(jī)驗(yàn)證碼:
1、clearRect:context.clearRect(x,y,width,height);清空給定矩形內(nèi)的指定像素
2、fillStyle:設(shè)置畫筆的顏色
3、rotate(deg):旋轉(zhuǎn)角度,以弧度旋轉(zhuǎn)(弧度=degrees*Math.PI/180 )
4、translate(): 方法重新映射畫布上的位置
5、Math.random():獲取0-1之間的一個(gè)隨機(jī)數(shù),不包含1
<!-- HTML --> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canvas隨機(jī)驗(yàn)證碼</title> </head> <body> <canvas id="canvas" width="100" height="40" style="border: 1px solid red;display: block;margin: 0 auto;"></canvas> </body> <script type="text/javascript"> var myCanvas = document.querySelector("#canvas"); var blur = myCanvas.getContext("2d"); // 當(dāng)點(diǎn)擊畫布時(shí)創(chuàng)建一個(gè)新的路徑 // 驗(yàn)證碼封裝 myCanvas.onclick = function() { // 實(shí)現(xiàn)點(diǎn)擊畫布創(chuàng)建一個(gè)新的驗(yàn)證碼 blur.clearRect(0,0,100,40); verify(); } verify(); function verify() { // 繪制矩形框 // blur.strokeRect(0,0,100,40); // 隨機(jī)驗(yàn)證碼 var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "F", "G", "H", "I", "J", "K", "L", "S", "T", "U", "V", "W", "X", "Y", "Z" ]; // 顯示四位數(shù)的驗(yàn)證碼 for (var i = 0; i < 4; i++) { var x = 20 + 20 * i; var y = 20 + 10 * Math.random(); // console.log(x,y); // 在數(shù)組中獲取到隨機(jī)的索引整數(shù) var index = Math.floor(Math.random() * arr.length); // 通過(guò)隨機(jī)的索引獲取到隨機(jī)的元素 var texts = arr[index]; // 設(shè)置驗(yàn)證碼的相關(guān)樣式 blur.font = "bold 20px 微軟雅黑"; blur.fillStyle = textColor(); // 畫布旋轉(zhuǎn)顯示 // translate() 方法重新映射畫布上的位置 blur.translate(x, y); // 將畫布旋轉(zhuǎn),旋轉(zhuǎn)角度,以弧度旋轉(zhuǎn)(弧度=degrees*Math.PI/180 ) var deg = 90 * Math.random() * Math.PI / 180; blur.rotate(deg); // blur.fillText(texts, 0, 0); // 將畫布映射返回原來(lái)的位置 blur.rotate(-deg); blur.translate(-x, -y); } // 制作驗(yàn)證碼的干擾線制作 for(var i=0;i<6;i++){ blur.beginPath(); blur.moveTo(Math.random()*100,Math.random()*40); blur.lineTo(Math.random()*100,Math.random()*40); // 設(shè)置干擾線的顏色 blur.strokeStyle=textColor(); blur.stroke(); } // 制作驗(yàn)證碼的干擾圓點(diǎn) for(var i=0;i<20;i++){ blur.beginPath(); var x=Math.random()*100; var y=Math.random()*100; blur.moveTo(x,y); blur.lineTo(x+1,y+1); // 設(shè)置干擾線的顏色 blur.strokeStyle=textColor(); blur.stroke(); } } // 獲取隨機(jī)顏色封裝 function textColor(){ var red=Math.floor(Math.random()*256); var green=Math.floor(Math.random()*256); var blue=Math.floor(Math.random()*256); return "rgb("+red+","+green+","+blue+")"; } </script> </html>
x | 要清除的矩形左上角的 x 坐標(biāo) |
y | 要清除的矩形左上角的 y 坐標(biāo) |
width | 要清除的矩形的寬度,以像素計(jì) |
height | 要清除的矩形的高度,以像素計(jì) |
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js實(shí)現(xiàn)隨機(jī)數(shù)字字母驗(yàn)證碼
- JavaScript 隨機(jī)驗(yàn)證碼的生成實(shí)例代碼
- js隨機(jī)生成一個(gè)驗(yàn)證碼
- 基于JS實(shí)現(xiàn)一個(gè)隨機(jī)生成驗(yàn)證碼功能
- JS如何生成隨機(jī)驗(yàn)證碼
- js實(shí)現(xiàn)隨機(jī)8位驗(yàn)證碼
- JavaScript實(shí)現(xiàn)隨機(jī)五位數(shù)驗(yàn)證碼
- JS 實(shí)現(xiàn)隨機(jī)驗(yàn)證碼功能
- JS實(shí)現(xiàn)4位隨機(jī)驗(yàn)證碼
- JavaScript實(shí)現(xiàn)隨機(jī)碼的生成與校驗(yàn)
相關(guān)文章
javascript使用location.search的示例
本文介紹javascript 使用location.search獲取當(dāng)前地址欄參數(shù)的實(shí)例2013-11-11

bootstrap table方法之expandRow-collapseRow展開或關(guān)閉當(dāng)前行數(shù)據(jù)

詳解使用mocha對(duì)webpack打包的項(xiàng)目進(jìn)行"冒煙測(cè)試"的大致流程

jscript之Read an Excel Spreadsheet