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

JavaScript生成隨機(jī)驗(yàn)證碼代碼實(shí)例

 更新時(shí)間:2019年09月28日 11:45:19   作者:Mr小zhou  
這篇文章主要介紹了JavaScript生成隨機(jī)驗(yàn)證碼代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

利用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í)有所幫助,也希望大家多多支持腳本之家。

  • 微信小程序?qū)悠吲T拼鎯?chǔ)的方法

    微信小程序?qū)悠吲T拼鎯?chǔ)的方法

    本篇文章主要介紹了小程序?qū)悠吲T拼鎯?chǔ)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • bootstrap table方法之expandRow-collapseRow展開或關(guān)閉當(dāng)前行數(shù)據(jù)

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

    這篇文章主要為大家詳細(xì)介紹了bootstrap table方法之expandRow-collapseRow展開或關(guān)閉當(dāng)前行數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • 詳解使用mocha對(duì)webpack打包的項(xiàng)目進(jìn)行

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

    這篇文章主要介紹了詳解使用mocha對(duì)webpack打包的項(xiàng)目進(jìn)行"冒煙測(cè)試"的大致流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • JS中類或?qū)ο蟮亩x說(shuō)明

    JS中類或?qū)ο蟮亩x說(shuō)明

    本篇文章主要是對(duì)JS中類或?qū)ο蟮亩x進(jìn)行了說(shuō)明介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2014-03-03
  • 詳解JavaScript類型判斷的四種方法

    詳解JavaScript類型判斷的四種方法

    這篇文章主要介紹了JavaScript類型判斷的四種方法,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下
    2020-10-10
  • JS原型對(duì)象通俗"唱法"

    JS原型對(duì)象通俗"唱法"

    書上對(duì)于原型對(duì)象的說(shuō)法給我整的眼花繚亂,完全不知道它在說(shuō)什么,查了好多資料,終于有了些理解,下面我以通俗的大白話說(shuō)說(shuō)我對(duì)原型對(duì)象的理解
    2012-12-12
  • layui 彈出刪除確認(rèn)界面的實(shí)例

    layui 彈出刪除確認(rèn)界面的實(shí)例

    今天小編就為大家分享一篇layui 彈出刪除確認(rèn)界面的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • jscript之Read an Excel Spreadsheet

    jscript之Read an Excel Spreadsheet

    jscript之Read an Excel Spreadsheet...
    2007-06-06
  • 最新評(píng)論