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

js實現隨機8位驗證碼

 更新時間:2020年07月24日 08:48:48   作者:fanfan_h  
這篇文章主要為大家詳細介紹了js實現隨機8位驗證碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

開發(fā)思路:

1.畫出放置驗證碼的模塊、一個寫有“看不清…”的小塊,以及輸入驗證碼的文本框
2.獲取各個模塊
3.封裝一個函數Yan_ma(),設置驗證碼為8位,里面含有數字,小寫字母,小寫字母和中文。每種類型出現的可能性為25%。
4.隨機數字在0-9,之間。對Math.ramand()向下取整。
5.隨機大小寫字母使用fromCharCode() 方法:將 Unicode 編碼轉為一個字符,例如:

var n = String.fromCharCode(65);
cosole.log(n);
//輸出j結果為A

大寫字母(65-91) 小寫字母(97-123)

var s = String.fromCharCode(Math.floor(Math.random() * 26 + 65));
var s = String.fromCharCode(Math.floor(Math.random() * 26 + 97));

6.隨機中文,聲明變量letter放置中文字符串,使用charAt()隨機在letter中獲得某個漢字。

var letter = "如若可以親愛的請許我青燈墨下執(zhí)一筆素箋今生為你吟盡千回百轉念";
var s = letter.charAt(Math.floor(Math.random() * letter.length));

7.給每位驗證碼設隨機的顏色,字體大小,相對文本位置,旋轉角度。給顏色封裝一個函數,使用十六進制顏色(如:#ffffff)

//隨機顏色
 function fontcolor(){
  var s1="";
  for(var k=0;k<6;k++){
   var z=[0,1,2,3,4,5,6,7,8,9,"a","b","c","d","e","f"];
   var m=z[Math.floor(Math.random() * z.length)];
   s1 +=m;
  }
  return "#"+s1;
  }

隨機位置和隨機旋轉角度的方法相同

隨機位置可能為向上下左右偏移 8px, 隨機旋轉角度可能為繞著z軸旋轉(±45度)。

8.提前聲明一個空字符串 str 讓每位驗證碼用字符串連接起來.

var s = String.fromCharCode(Math.floor(Math.random() * 26 + 97));
str+="<span style ='transform:rotatez("+ zhuan +"deg);left:"+topset+"px; color: " +color +" ;font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
 arr+=s;

9.讓8位驗證碼出現在第一個大模塊中的innerHTML中。

10.給寫有“看不清”的span標簽添加點擊事件,點擊時,調用函數Yan_ma,刷新驗證碼。

11.如果輸入的驗證碼不正確,則彈出“驗證成功”,否則彈出“驗證失敗”。

<!DOCTYPE html>
<html>
<head lang="en">
 <meta charset="UTF-8">
 <title>隨機驗證碼</title>
 <script>
 var arr="";
 window.onload=function() {
  var maa = document.getElementsByClassName("block")[0];
  var looking = document.getElementById("look");
  var put = document.getElementById("text");
  var btnn = document.getElementById("btn");
  Yan_ma(maa);
  looking.onclick=function (){
  Yan_ma(maa);
  };
  btnn.onclick=function(){
  if(put.value.toLowerCase()==arr.toLowerCase()){
   alert ("驗證成功");
  }
  else{
   alert ("驗證失敗");
   Yan_ma(maa);
  }
  }

 };


  function Yan_ma(aim) {
  arr ="";
  var str="";
  for (var i = 0; i < 8; i++) {
   //隨機數 Math.random 0-1 的隨機值
   var n = Math.random();
   //隨機顏色
   var color=fontcolor();
   //隨機大小
   var size=Math.floor (Math.random ()*12 +20);
   //隨機位置
   var g=Math.random() <0.5 ? -1: 1;
   var topset=Math.random ()*g*8;
   //隨機旋轉
   var h=Math.random() <0.5 ? -1: 1;
   var zhuan=Math.random ()*h*45;
   if (n < 0.25) {
   //隨機數字
   var s = Math.floor(Math.random() * 10);
   str+="<span style='transform:rotatez("+ zhuan +"deg);left:"+topset+"px; color: " +color +";font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
   arr+=s;
   }
   //隨機大寫字母 //65-91
   else if (n >= 0.25 && n < 0.5) {
   var s = String.fromCharCode(Math.floor(Math.random() * 26 + 65));
   str+="<span style='transform:rotatez("+ zhuan +"deg); left:"+topset+"px; color: " +color +";font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
   arr+=s;
   }
   //隨機小寫字母 97-123
   else if (n >=0.5 && n < 0.75) {
   var s = String.fromCharCode(Math.floor(Math.random() * 26 + 97));
   str+="<span style ='transform:rotatez("+ zhuan +"deg);left:"+topset+"px; color: " +color +" ;font-size:"+size+"px ;top:"+topset+"px'>"+s+"</span>";
   arr+=s;
   }
   //隨機文字
   else {
   var letter = "如若可以親愛的請許我青燈墨下執(zhí)一筆素箋今生為你吟盡千回百轉念";
   var s = letter.charAt(Math.floor(Math.random() * letter.length));
   str+="<span style='transform: rotatez("+ zhuan +" deg) ; left:"+topset+"px; color: " +color +";font-size:"+size+"px;top:"+topset+"px '>"+s+"</span>";
   arr+=s;
   }
  }
  aim.innerHTML =str;
  }

  function fontcolor(){
  var s1="";
  for(var k=0;k<6;k++){
   var z=[0,1,2,3,4,5,6,7,8,9,"a","b","c","d","e","f"];
   var m=z[Math.floor(Math.random() * z.length)];
   s1 +=m;
  }
  return "#"+s1;
  }

 </script>
 <style>
 .block{
  width:250px;
  height:60px;
  background:url("bg2.png") no-repeat center;
  background-size: 100%;
  text-align: center;
  line-height: 60px;
 }
 .block span{
  position: relative;
  display: inline-block;
  width:20px;
  margin:5px 3px;
 }
 #look{
  color: #9200ff;
 }
 #look:hover{
  cursor: pointer;
 }
 </style>
</head>
<body>
<div class="block">
</div>
<span id="look">看不清...</span>
<br/>
<input type="text" id="text" placeholder="請輸入驗證碼" />
<button id="btn">驗證</button>
</body>
</html>

出現的驗證碼

當輸入正確驗證碼時

當沒輸入錯誤驗證碼時

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 原生js實現鍵盤控制div移動且解決停頓問題

    原生js實現鍵盤控制div移動且解決停頓問題

    這篇文章主要給大家介紹了如何利用原生js實現鍵盤控制div移動,并且解決在移動過程中的停頓問題,文中給出了詳細的示例代碼,相信對大家的理解和學習很有幫助,下面跟著小編一起來看看吧。
    2016-12-12
  • 10行原生JS實現文字無縫滾動(超簡單)

    10行原生JS實現文字無縫滾動(超簡單)

    下面小編就為大家分享一篇10行原生JS實現文字無縫滾動的效果,特別簡單,具有很好的參考價值,希望對大家有所幫助
    2018-01-01
  • JS動態(tài)改變表格邊框寬度的方法

    JS動態(tài)改變表格邊框寬度的方法

    這篇文章主要介紹了JS動態(tài)改變表格邊框寬度的方法,實例分析了javascript操作table表格中border屬性的技巧,需要的朋友可以參考下
    2015-03-03
  • JS小功能(offsetLeft實現圖片滾動效果)實例代碼

    JS小功能(offsetLeft實現圖片滾動效果)實例代碼

    這篇文章主要介紹了offsetLeft實現圖片滾動效果實例代碼,有需要的朋友可以參考一下
    2013-11-11
  • 使用flutter創(chuàng)建可移動的stack小部件功能

    使用flutter創(chuàng)建可移動的stack小部件功能

    本文主要介紹我為桌面和 Web 設計的一個超級秘密 Flutter 項目使用了畫布和可拖動節(jié)點界面。本教程將展示我如何使用堆棧來使用小部件完成可拖動功能,需要的朋友可以參考下
    2021-10-10
  • js對url進行編碼解碼的三種方式總結

    js對url進行編碼解碼的三種方式總結

    為一個字符串進行URL編碼很容易,只需要調用encodeURI,傳入要編碼的字符串即可,而且實現的方法不止這一個,下面這篇文章主要給大家介紹了關于js對url進行編碼解碼的三種方式,需要的朋友可以參考下
    2023-02-02
  • Bootstrap每天必學之導航條(二)

    Bootstrap每天必學之導航條(二)

    Bootstrap每天必學之導航條,進一步向大家講解了導航條養(yǎng)殖,以及導航條中元素的使用方法,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Javascript 是你的高階函數(高級應用)

    Javascript 是你的高階函數(高級應用)

    這篇文章主要介紹了Javascript 是你的高階函數 ,需要的朋友可以參考下
    2015-06-06
  • JS實現隨機顏色的3種方法與顏色格式的轉化

    JS實現隨機顏色的3種方法與顏色格式的轉化

    隨機顏色和顏色格式是我們在開發(fā)中經常要用到的一個小功能,網上相關的資料也很多,想著有必要總結一下自己的經驗。所以這篇文章主要介紹了JS實現隨機顏色的3種方法與顏色格式的轉化,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01
  • 一個兼容FF的智能超長文章分頁JS

    一個兼容FF的智能超長文章分頁JS

    這篇文章主要介紹了一個兼容FF的智能超長文章分頁JS的相關資料,需要的朋友可以參考下
    2007-07-07

最新評論