如何基于JS實(shí)現(xiàn)一個(gè)隨機(jī)生成驗(yàn)證碼功能-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)主營侯馬網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,APP應(yīng)用開發(fā),侯馬h5微信平臺(tái)小程序開發(fā)搭建,侯馬網(wǎng)站營銷推廣歡迎侯馬等地區(qū)企業(yè)咨詢

效果展示

如何基于JS實(shí)現(xiàn)一個(gè)隨機(jī)生成驗(yàn)證碼功能

實(shí)現(xiàn)原理

  1. html:一般就是一個(gè)div: <div id="code"></div> ,樣式根據(jù)需求設(shè)計(jì)。

  2. JS:1)將所有的驗(yàn)證碼所用的字符放在一個(gè)字符串中

       2)在這個(gè)字符串的字符個(gè)數(shù)以內(nèi),隨機(jī)生成索引號

      3)根據(jù)索引號查找對應(yīng)字符,拼接成驗(yàn)證碼的字符串

代碼實(shí)現(xiàn)

HTML:

<div id="code"></div>

CSS:

* {
  margin: 0;
  padding: 0;
}
div {
  width: 80px;
  height: 30px;
  font-size: 18px;
  line-height: 30px;
  text-align: center;
  color: #333;
  border: 1px solid red;
  margin: 100px auto;
  cursor: pointer;
}

JavaScript:

var codeStr = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
var oDiv = document.getElementById('code');
// 用來生成隨機(jī)整數(shù)
function getRandom(n, m) { // param: (Number, Number)
  n = Number(n);
  m = Number(m);
  // 確保 m 始終大于 n
  if (n > m) {
    var temp = n;
    n = m;
    m = temp;
  }
  // 下有詳細(xì)說明
  return Math.floor(Math.random()*(m - n) + n);
}
// 將隨機(jī)生成的整數(shù)下標(biāo)對應(yīng)的字母放入div中
function getCode() {
  var str = '';
  // 驗(yàn)證碼有幾位就循環(huán)幾次
  for (var i = 0;i < 4;i ++) {
    var ran = getRandom(0, 62);
    str += codeStr.charAt(ran);
  }
  oDiv.innerHTML = str;
}
getCode();// 調(diào)用函數(shù),頁面刷新也會(huì)刷新驗(yàn)證碼
// 點(diǎn)擊刷新驗(yàn)證碼
oDiv.onclick = function(){
  getCode();
}

代碼分析

JS:

1)將所有的驗(yàn)證碼所用的字符放在一個(gè)字符串中

             -- > 代碼第1行,除了字母數(shù)字也可放入中文漢字等。

        2)在這個(gè)字符串的字符個(gè)數(shù)以內(nèi),隨機(jī)生成索引號

             -- > 第4行的函數(shù)用于生成隨機(jī)整數(shù),參數(shù) (n, m)為數(shù)字,Number()確保是數(shù)字

        默認(rèn)m > n,防止傳參有誤,用if判斷后改正

        Math.random() -- > [0,1)

        Math.random() * (m - n) -- > [0, m - n)

        Math.random() * (m - n) + n -- > [n, m)

        為了能將codeStr所有的下標(biāo)都取到,上述m若是codeStr.length,想要取值能取到最后一位,再使用Math.floor()向下取整。

        n 為 0,m 為 codeStr.length 則隨機(jī)范圍為codeStr的所有元素下標(biāo)。例(n, m) -- > (0, 62)計(jì)算后的取值范圍:下標(biāo)為[0, 61]的整數(shù)。

        3)根據(jù)下標(biāo)查找對應(yīng)元素,拼接成驗(yàn)證碼的字符串

        第17行的函數(shù)getCode()獲取字符串中對應(yīng)元素,并拼接成字符串返回到頁面中。最后點(diǎn)擊div可不斷生成隨機(jī)驗(yàn)證碼。

完整代碼

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>隨機(jī)生成驗(yàn)證碼</title>
  <style>
  * {
    margin: 0;
    padding: 0;
  }
  div {
    width: 80px;
    height: 30px;
    font-size: 18px;
    line-height: 30px;
    text-align: center;
    color: #333;
    border: 1px solid red;
    margin: 100px auto;
    cursor: pointer;
  }
  </style>
</head>

<body>
  <div id="code"></div>

  <script>
  var codeStr = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
  var oDiv = document.getElementById('code');
  // 用來生成隨機(jī)整數(shù)
  function getRandom(n, m) { // param: (Number, Number)
    n = Number(n);
    m = Number(m);
    // 確保 m 始終大于 n
    if (n > m) {
      var temp = n;
      n = m;
      m = temp;
    }
    return Math.floor(Math.random()*(m - n) + n);
  }
  // 將隨機(jī)生成的整數(shù)下標(biāo)對應(yīng)的字母放入div中
  function getCode() {
    var str = '';
    // 驗(yàn)證碼有幾位就循環(huán)幾次
    for (var i = 0;i < 4;i ++) {
      var ran = getRandom(0, 62);
      str += codeStr.charAt(ran);
    }
    oDiv.innerHTML = str;
  }
  getCode();// 調(diào)用函數(shù),頁面刷新也會(huì)刷新驗(yàn)證碼
  // 點(diǎn)擊刷新驗(yàn)證碼
  oDiv.onclick = function(){
    getCode();
  }
  </script>
</body>
</html>

以上是“如何基于JS實(shí)現(xiàn)一個(gè)隨機(jī)生成驗(yàn)證碼功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(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元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)站欄目:如何基于JS實(shí)現(xiàn)一個(gè)隨機(jī)生成驗(yàn)證碼功能-創(chuàng)新互聯(lián)
鏈接地址:http://bm7419.com/article16/hohgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計(jì)公司、電子商務(wù)、網(wǎng)站建設(shè)、微信公眾號域名注冊、靜態(tài)網(wǎng)站

廣告

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

成都定制網(wǎng)站網(wǎng)頁設(shè)計(jì)