欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript使用canvas繪制隨機(jī)驗(yàn)證碼

 更新時(shí)間:2020年02月17日 15:48:04   作者:一只前端小白  
這篇文章主要為大家詳細(xì)介紹了JavaScript使用canvas繪制隨機(jī)驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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

理論基礎(chǔ):

掌握使用canvas繪制線條和圓形以及繪制文字

實(shí)現(xiàn)思路:

先構(gòu)建一個(gè)畫(huà)布,設(shè)置一定的寬高(在canvas中設(shè)置寬高和在style中設(shè)置是有區(qū)別的,建議直接在canvas標(biāo)簽中設(shè)置),封裝一個(gè)生成隨機(jī)數(shù)的方法,為線條和圓形的繪制設(shè)置隨機(jī)的位置,既然是隨機(jī)的,必然是有隨機(jī)的區(qū)間,先獲取畫(huà)布的寬高,線條和圓的位置就是(0~畫(huà)布的寬高區(qū)間)的隨機(jī)位置,再定義一個(gè)隨機(jī)字符,獲取隨機(jī)的索引值,即可生成隨機(jī)的驗(yàn)證碼。需要刷新,直接把以下代碼封裝在函數(shù)里,用一個(gè)事件觸發(fā)即可。

源代碼:

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport"
 content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>canvas驗(yàn)證碼</title>
</head>
<body>
<canvas id="code" width="80" height="30" style="border: 1px solid #ccc"></canvas>

<script src="jq/jquery-3.2.1.min.js"></script>
<script>
 var canvasW=$("#code").width();
 var canvasH=$("#code").height();
 //獲取任意區(qū)間隨機(jī)數(shù)
 var getRandom=function (maxNum) {
 return Math.floor(Math.random()*maxNum);
 }
 //隨機(jī)顏色
 var getColor=function () {
 var r=getRandom(256),
 g=getRandom(256),
 b=getRandom(256);
 return "rgb("+[r,g,b].join(',')+")";
 }
 var ctx=$("#code")[0].getContext("2d");
 var lineNum=3,arcNum=20;

 //繪制線
 for (var i=0;i<lineNum;i++){
 ctx.beginPath();
 ctx.moveTo(getRandom(canvasW),getRandom(canvasH));
 ctx.lineTo(getRandom(canvasW),getRandom(canvasH));
 ctx.strokeStyle=getColor();
 ctx.closePath();
 ctx.stroke();
 }
 //繪制點(diǎn)
 for (var i=0;i<arcNum;i++){
 ctx.beginPath();
 ctx.arc(getRandom(canvasW),getRandom(canvasH),1,0,2*Math.PI);
 ctx.fillStyle=getColor();
 ctx.closePath();
 ctx.fill();
 }
 //繪制驗(yàn)證碼
 var codeTxt="ABCDEFGHIJKLIMNOPQRSTUVWSYZ1234567890";;
 for(var i=0;i<4;i++){
 var txt=codeTxt.split("")[getRandom(codeTxt.length)];
 //繪制驗(yàn)證碼
 ctx.beginPath();
 ctx.font="23px 微軟雅黑";
 ctx.fillStyle=getColor();
 ctx.fillText(txt,20*i,25);
 ctx.closePath();
 }
</script>
</body>
</html>

最終效果:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 原生js實(shí)現(xiàn)圖片輪播特效

    原生js實(shí)現(xiàn)圖片輪播特效

    這篇文章主要介紹了原生js實(shí)現(xiàn)圖片輪播特效,適合用于商品展示,實(shí)現(xiàn)最簡(jiǎn)單的廣告輪播效果,感興趣的小伙伴們可以參考一下
    2015-12-12
  • BootStrap select2 動(dòng)態(tài)改變值的方法

    BootStrap select2 動(dòng)態(tài)改變值的方法

    這篇文章主要介紹了BootStrap select2 動(dòng)態(tài)改變值的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-02-02
  • js實(shí)現(xiàn)class樣式的修改、添加及刪除的方法

    js實(shí)現(xiàn)class樣式的修改、添加及刪除的方法

    這篇文章主要介紹了js實(shí)現(xiàn)class樣式的修改、添加及刪除的方法,主要通過(guò)修改標(biāo)簽的className來(lái)實(shí)現(xiàn)這一功能,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-01-01
  • 解決canvas畫(huà)布使用fillRect()時(shí)高度出現(xiàn)雙倍效果的問(wèn)題

    解決canvas畫(huà)布使用fillRect()時(shí)高度出現(xiàn)雙倍效果的問(wèn)題

    下面小編就為大家?guī)?lái)一篇解決canvas畫(huà)布使用fillRect()時(shí)高度出現(xiàn)雙倍效果的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • 在微信小程序中使用mqtt服務(wù)的方法

    在微信小程序中使用mqtt服務(wù)的方法

    這篇文章主要介紹了在微信小程序中使用mqtt服務(wù)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • js腳本獲取webform服務(wù)器控件的方法

    js腳本獲取webform服務(wù)器控件的方法

    asp.net webform中獲取服務(wù)器控件,js腳本獲取服務(wù)器控件需要使用ClientID,下面有個(gè)示例,大家可以參考下
    2014-05-05
  • Flash圖片上傳組件 swfupload使用指南

    Flash圖片上傳組件 swfupload使用指南

    這篇文章主要介紹了Flash圖片上傳組件 swfupload使用方法及示例,swfupload的使用范圍十分的廣泛,功能也很強(qiáng)大,今天我們就先來(lái)簡(jiǎn)單的通過(guò)范例來(lái)學(xué)習(xí)下。
    2015-03-03
  • 一文詳解JavaScript閉包典型應(yīng)用

    一文詳解JavaScript閉包典型應(yīng)用

    這篇文章主要介紹了關(guān)于Javascript閉包典型應(yīng)用,文中有非常詳細(xì)的代碼示例.對(duì)正在學(xué)習(xí)js的伙伴們有很好的幫助,需要的朋友可以參考下
    2022-04-04
  • JavaScript 字符串常用操作小結(jié)(非常實(shí)用)

    JavaScript 字符串常用操作小結(jié)(非常實(shí)用)

    這篇文章主要介紹了JavaScript 字符串常用操作的知識(shí),包括字符串截取,查找類的方法,對(duì)js字符串操作相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2016-11-11
  • JS實(shí)現(xiàn)的豎向折疊菜單代碼

    JS實(shí)現(xiàn)的豎向折疊菜單代碼

    這篇文章主要介紹了JS實(shí)現(xiàn)的豎向折疊菜單代碼,涉及JavaScript動(dòng)態(tài)遍歷頁(yè)面元素及樣式修改的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10

最新評(píng)論