JS怎樣生成隨機(jī)驗(yàn)證碼-創(chuàng)新互聯(lián)

小編給大家分享一下JS怎樣生成隨機(jī)驗(yàn)證碼,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

10年積累的網(wǎng)站制作、成都網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶(hù)對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶(hù)得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有江北免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

具體內(nèi)容如下

JS怎樣生成隨機(jī)驗(yàn)證碼

在網(wǎng)站中我們很常見(jiàn)到形形色色的驗(yàn)證碼,今天我們來(lái)用JS來(lái)生成一個(gè)隨機(jī)的二維碼。

我們需要用到canvas來(lái)進(jìn)行驗(yàn)證碼的繪制

什么是Canvas

HTML5 的 canvas 元素使用 JavaScript 在網(wǎng)頁(yè)上繪制圖像。
畫(huà)布是一個(gè)矩形區(qū)域,您可以控制其每一像素。
canvas 擁有多種繪制路徑、矩形、圓形、字符以及添加圖像的方法。

思路

我們要做的二維碼首先要有隨機(jī)的數(shù)字,其次就是要有隨機(jī)的位置。

HTML

<canvas id="canvas" >
</canvas>

JS

function getVerification() { //二維碼
 var ctx = document.getElementById("canvas").getContext("2d");
 // 清空畫(huà)布
 ctx.clearRect(0,0, 400, 400);
 // 設(shè)置字體
 ctx.font = "128px bold 黑體";
 // 設(shè)置垂直對(duì)齊方式
 ctx.textBaseline = "top";
 // 設(shè)置顏色
 ctx.fillStyle = randomColor();
 // 繪制文字(參數(shù):要寫(xiě)的字,x坐標(biāo),y坐標(biāo))
 ctx.fillText(getRandomNum(10), 0, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 50, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 100, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 150, getRandomNum(50));
}

我們使用ctx.fillStyle = randomColor();來(lái)設(shè)置隨機(jī)的顏色,每寫(xiě)一個(gè)數(shù)字換一個(gè)顏色,randomColoe()函數(shù)代碼如下,可以隨機(jī)生成十六進(jìn)制顏色碼。

function randomColor() {
 var colorValue = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f";
 var colorArray = colorValue.split(",");
 var color = "#";
 for (var i = 0; i < 6; i++) {
 color += colorArray[Math.floor(Math.random() * 16)];
 }
 return color;
}

我們使用getRandomNum()來(lái)獲取隨機(jī)顯示的數(shù)字和隨機(jī)每次字體的y軸方向的位置。驗(yàn)證碼的每個(gè)數(shù)字分別進(jìn)行獲取。傳入的參數(shù)n來(lái)確定隨機(jī)數(shù)范圍。代碼如下:

function getRandomNum(n){
 return parseInt(Math.random() * n); 
}

完整代碼:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>2</title>
</head>

<body>
 <canvas id="canvas" ></canvas>
 <span id="yanzhengma"></span><button onclick="getVerification()">看不清</button>
 <script>
 function randomColor() {
 var colorValue = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f";
 var colorArray = colorValue.split(",");
 var color = "#";
 for (var i = 0; i < 6; i++) {
 color += colorArray[Math.floor(Math.random() * 16)];
 }
 return color;
 }
 function getRandomNum(n){
 return parseInt(Math.random() * n); 
 }
 function getVerification() {
 var ctx = document.getElementById("canvas").getContext("2d");
 ctx.clearRect(0,0, 400, 400);
 // 設(shè)置字體
 ctx.font = "128px bold 黑體";
 // 設(shè)置垂直對(duì)齊方式
 ctx.textBaseline = "top";
 // 設(shè)置顏色
 ctx.fillStyle = randomColor();
 // 繪制文字(參數(shù):要寫(xiě)的字,x坐標(biāo),y坐標(biāo))
 ctx.fillText(getRandomNum(10), 0, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 50, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 100, getRandomNum(50));
 ctx.fillStyle = randomColor();
 ctx.fillText(getRandomNum(10), 150, getRandomNum(50));
 }
 getVerification();
 </script>
</body>
</html>

以上是“JS怎樣生成隨機(jī)驗(yàn)證碼”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線(xiàn),公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。

分享題目:JS怎樣生成隨機(jī)驗(yàn)證碼-創(chuàng)新互聯(lián)
文章地址:http://bm7419.com/article44/dgcche.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站建設(shè)動(dòng)態(tài)網(wǎng)站、App開(kāi)發(fā)響應(yīng)式網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)