jQuery短信驗證倒計時功能實現(xiàn)方法詳解
來源:易賢網 閱讀:1408 次 日期:2016-06-23 14:49:02
溫馨提示:易賢網小編為您整理了“jQuery短信驗證倒計時功能實現(xiàn)方法詳解”,方便廣大網友查閱!

本文實例講述了jQuery短信驗證倒計時功能實現(xiàn)方法。分享給大家供大家參考,具體如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >

<head>

<title>demo 短信驗證碼60秒,并限制次數</title>

<script src="js/time.js" type="text/javascript"></script>

</head>

<body>

<div class="input">

  <input type="button" id="btn" class="btn_mfyzm" value="獲取驗證碼" />

</div>

</body>

<script>

var wait=60*2;

document.getElementById("btn").disabled = false;

function time(o) {

    if (wait == 0) {

      o.removeAttribute("disabled");

      o.value="免費獲取驗證碼";

      wait = 60*2;

    } else {

      o.setAttribute("disabled", true);

      o.value="重新發(fā)送(" + wait + ")";

      wait--;

      setTimeout(function() {

        time(o)

      },

      1000)

    }

  }

document.getElementById("btn").onclick=function(){time(this);}

</script>

</html>

time.js內容如下:

var InterValObj; //timer變量,控制時間

var count = 60; //間隔函數,1秒執(zhí)行

var curCount;//當前剩余秒數

var code = ""; //驗證碼

var codeLength = 6;//驗證碼長度

function sendMessage() {

  curCount = count;

  var dealType; //驗證方式

  var uid=$("#uid").val();//用戶uid

  if ($("#phone").attr("checked") == true) {

    dealType = "phone";

  }

  else {

    dealType = "email";

  }

  //產生驗證碼

  for (var i = 0; i < codeLength; i++) {

    code += parseInt(Math.random() * 9).toString();

  }

  //設置button效果,開始計時

    $("#btnSendCode").attr("disabled", "true");

    $("#btnSendCode").val("請在" + curCount + "秒內輸入驗證碼");

    InterValObj = window.setInterval(SetRemainTime, 1000); //啟動計時器,1秒執(zhí)行一次

  //向后臺發(fā)送處理數據

    $.ajax({

      type: "POST", //用POST方式傳輸

      dataType: "text", //數據格式:JSON

      url: 'Login.ashx', //目標地址

      data: "dealType=" + dealType +"&uid=" + uid + "&code=" + code,

      error: function (XMLHttpRequest, textStatus, errorThrown) { },

      success: function (msg){ }

    });

}

//timer處理函數

function SetRemainTime() {

  if (curCount == 0) {

    window.clearInterval(InterValObj);//停止計時器

    $("#btnSendCode").removeAttr("disabled");//啟用按鈕

    $("#btnSendCode").val("重新發(fā)送驗證碼");

    code = ""; //清除驗證碼。如果不清除,過時間后,輸入收到的驗證碼依然有效

  }

  else {

    curCount--;

    $("#btnSendCode").val("請在" + curCount + "秒內輸入驗證碼");

  }

}

希望本文所述對大家jQuery程序設計有所幫助。

更多信息請查看網絡編程
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網