• js模拟支付宝发送短信验证码&&&&短信倒计时


    html

    <div class="pwdContent">
    <div class="pwdBox"></div>
    <div class="pwdErrorPoint">请输入数字!</div>

    </div>

    js
    // 短信验证码
    /*动态生成*/
    var pwdBox = document.getElementsByClassName("pwdBox")[0];

    function createDIV1(num) {
    for (var i = 0; i < num; i++) {
    var pawDiv = document.createElement("div");
    pawDiv.className = "pawDivVali";
    pwdBox.appendChild(pawDiv);
    var paw = document.createElement("input");
    paw.type = "password";
    paw.className = "pawVali";
    paw.maxLength = "1";
    paw.readOnly = "readonly";
    pawDiv.appendChild(paw);
    }
    }

    createDIV1(6);


    var pawDivVali = document.getElementsByClassName("pawDivVali");
    var pawVali = document.getElementsByClassName("pawVali");
    var pawDivCountVali = pawDivVali.length;
    /*设置第一个输入框默认选中*/
    // pawDiv[0].setAttribute("style","border: 2px solid deepskyblue;");
    pawVali[0].readOnly = false;
    pawVali[0].focus();

    var pwdErrorPoint = document.getElementsByClassName("pwdErrorPoint")[0];

    /*绑定pawDiv点击事件*/

    function func1() {
    for (var i = 0; i < pawDivCountVali; i++) {
    pawDivVali[i].addEventListener("click", function () {
    pawDivClick1(this);
    });
    pawVali[i].onkeyup = function (event) {
    console.log(event.keyCode);
    if (event.keyCode >= 48 && event.keyCode <= 57) {
    /*输入0-9*/
    changeDiv1();
    pwdErrorPoint.style.display = "none";

    } else if (event.keyCode == "8") {
    /*退格回删事件*/
    firstDiv1();

    } else if (event.keyCode == "13") {
    /*回车事件*/
    getPassword1();

    } else {
    /*输入非0-9*/
    pwdErrorPoint.style.display = "block";
    this.value = "";
    }

    };
    }

    }

    func1();


    /*定义pawDiv点击事件*/
    var pawDivClick1 = function (e) {
    for (var i = 0; i < pawDivCountVali; i++) {
    // pawDivVali[i].setAttribute("style","border:none");
    }
    };


    /*定义自动选中下一个输入框事件*/
    var changeDiv1 = function () {
    for (var i = 0; i < pawDivCountVali; i++) {
    if (pawVali[i].value.length == "1") {
    /*处理当前输入框*/
    pawVali[i].blur();
    /*处理上一个输入框*/
    // 添加背景点
    // paw[i].setAttribute("style","background: red;");
    if (i == 5) {
    alert("验证码输入是否正确")
    getPassword1();
    return
    }
    pawVali[i + 1].focus();
    pawVali[i + 1].readOnly = false;
    pawDivClick(pawVali[i + 1]);
    }
    }
    };

    /*回删时选中上一个输入框事件*/
    var firstDiv1 = function () {
    for (var i = 0; i < pawDivCountVali; i++) {
    console.log(i);
    if (pawVali[i].value.length == "0") {
    /*处理当前输入框*/
    console.log(i);
    pawVali[i].blur();
    /*处理上一个输入框*/
    pawVali[i - 1].focus();
    pawVali[i - 1].readOnly = false;
    pawVali[i - 1].value = "";
    pawDivClick(pawVali[i - 1]);
    break;
    }
    }
    };


    /*验证码输入错误直接回到第一个输入框事件*/
    var firstDiv2 = function () {
    for (var i = 0; i < pawDivCountVali; i++) {
    console.log(i);
    pawVali[i].value = ""
    /*处理当前输入框*/
    console.log(i);
    pawVali[i].blur();

    /*处理上一个输入框*/
    pawDivClick(pawVali[i]);

    }
    pawVali[0].focus();
    pawVali[0].readOnly = false;
    };


    /*获取输入密码*/
    var getPassword1 = function () {
    var n = "";
    for (var i = 0; i < pawDivCountVali; i++) {
    n += pawVali[i].value;
    }
    // 如果密码输入成功
    $(".pay-ui-btn").removeClass("disable")
    alert(n);
    $("#pursePayForm input[name='validateCode']").val(n)
    alert("验证码输入错误")
    $(".errorPointVali").css({display: 'block'})
    setTimeout(function () {
    $(".errorPointVali").css({display: 'none'})
    }, 2000)
    firstDiv2()
    };
    // var getPasswordBtn=document.getElementsByClassName("getPasswordBtn")[0];
    //
    // getPasswordBtn.addEventListener("click",getPassword);

    /*键盘事件*/
    document.onkeyup = function (event) {
    if (event.keyCode == "13") {
    /*回车事件*/
    getPassword();
    }
    };


    css

    .pwdBox {
    228px;
    height: 37px;
    border: 1px solid #ccc;
    margin-top: 10px;
    line-height: 30px;
    }

    #validateBox {
    position: relative;
    }

    .jp-logo-wrap {
    position: absolute;
    }

    .jp-logo-wrap .jp-logo {
    background-position: -51px -41px;
    102px;
    height: 35px;
    position: absolute;
    left: -34px;
    top: 5px;
    background: url('http://test.storage.jd.com/et-trade/pdf/receipt/20181019/cashier_two.jpg?Expires=1575941007&AccessKey=jZAZj2evo1DsyCu7&Signature=XWPKewwj1oNwdEKedpQOFzTOAwM%3D') no-repeat;
    }

    .index-cont-top span {
    background-position: -51px -77px;
    background: url('http://test.storage.jd.com/et-trade/pdf/receipt/20181019/cashier_two.jpg?Expires=1575941007&AccessKey=jZAZj2evo1DsyCu7&Signature=XWPKewwj1oNwdEKedpQOFzTOAwM%3D') no-repeat;
    border-bottom: 1px solid #eee;
    }






    // 短信验证码倒计时

    html

    <div class="validSend">
    <input type="button" id="btn" value="免费获取验证码" onclick="settime(this)"/>
    </div>

    js

    var countdown = 60;

    function settime(obj) {
    sedSms();
    if (countdown == 0) {
    obj.removeAttribute("disabled");
    obj.value = "免费获取验证码";
    countdown = 60;
    return;
    } else {
    obj.setAttribute("disabled", true);
    obj.value = "重新发送(" + countdown + ")";
    countdown--;
    }
    setTimeout(function () {
    settime(obj)
    }
    , 1000)
    }
  • 相关阅读:
    我不写博客的原因就是cnblogs不好用
    使用KeePass愉快的来管理你的密码
    Visual studio常用的code snippets
    日常工作小贴士
    win10下面visual studio, sublime ctrl+shift+f快捷键失效的原因
    Markdown常用语法对应
    常见的Message Queue应用场景
    二分查找(binary search)
    在ROS中使用花生壳的域名服务
    排序算法 选择排序(selection sort)
  • 原文地址:https://www.cnblogs.com/shuihanxiao/p/9908219.html
Copyright © 2020-2023  润新知