JS如何生成隨機(jī)驗(yàn)證碼
本文實(shí)例為大家分享了JS生成隨機(jī)驗(yàn)證碼的具體代碼,供大家參考,具體內(nèi)容如下

在網(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" style="border: 1px solid red; width: 80px; height: 40px;"> </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" style="border: 1px solid red; width: 80px; height: 40px;"></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>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js實(shí)現(xiàn)隨機(jī)數(shù)字字母驗(yàn)證碼
- js隨機(jī)生成一個(gè)驗(yàn)證碼
- JavaScript 隨機(jī)驗(yàn)證碼的生成實(shí)例代碼
- 用jsp頁(yè)面生成隨機(jī)的驗(yàn)證數(shù)字碼示例
- JavaScript實(shí)現(xiàn)隨機(jī)五位數(shù)驗(yàn)證碼
- 基于JS實(shí)現(xiàn)一個(gè)隨機(jī)生成驗(yàn)證碼功能
- js實(shí)現(xiàn)隨機(jī)8位驗(yàn)證碼
- JS實(shí)現(xiàn)4位隨機(jī)驗(yàn)證碼
- JS 實(shí)現(xiàn)隨機(jī)驗(yàn)證碼功能
- Javascript實(shí)現(xiàn)仿QQ隨機(jī)數(shù)驗(yàn)證
相關(guān)文章
如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡
這篇文章主要介紹了如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
小程序顯示彈窗時(shí)禁止下層的內(nèi)容滾動(dòng)實(shí)現(xiàn)方法
這篇文章主要介紹了小程序顯示彈窗時(shí)禁止下層的內(nèi)容滾動(dòng)實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-03-03
js位運(yùn)算在實(shí)際中使用的實(shí)例教程
我們可能很少在編程中用位運(yùn)算,如果沒(méi)深入學(xué)習(xí),可能也很難理解,下面這篇文章主要給大家介紹了關(guān)于js位運(yùn)算在實(shí)際中使用的相關(guān)資料,需要的朋友可以參考下2022-03-03
總結(jié)AJAX相關(guān)JS代碼片段和瀏覽器模型
總結(jié)AJAX相關(guān)JS代碼片段和瀏覽器模型...2007-08-08
Net微信網(wǎng)頁(yè)開(kāi)發(fā) 使用微信JS-SDK獲取當(dāng)前地理位置過(guò)程詳解
這篇文章主要介紹了Net微信網(wǎng)頁(yè)開(kāi)發(fā) 使用微信JS-SDK獲取當(dāng)前地理位置過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
JavaScript設(shè)計(jì)模式之原型模式詳情
這篇文章主要介紹了JavaScript設(shè)計(jì)模式之原型模式詳情,原型的這種設(shè)計(jì)模式,是一種比較簡(jiǎn)單的設(shè)計(jì)模式,由于初始化都做一些重復(fù)性的東西,造成的性能消2022-06-06
js倒計(jì)時(shí)小實(shí)例(多次定時(shí))
這篇文章主要介紹了js實(shí)現(xiàn)可多次定時(shí)的倒計(jì)時(shí)小實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12

