微信小程序小工具之下发短信验证码倒计时

目标:
按钮倒计时
步骤:
用户点击按钮,提示下发短信,按钮进行倒计时
代码:

wxml

<view>
<input type="number" name="linkTel" bindblur="blurTel" value="{{agentTel}}" placeholder="*手机号码" maxlength="11" />
</view>
<button  bindtap="setVerify">{{VerifyCode}}</button>



js


//手机输入框遗失光标则获取value然后把数据放入this.data.linkTel中去
  blurTel: function (e) {
    var linkTel = e.detail.value.replace(/\s/g, "");
    this.setData({
      linkTel: linkTel
    })
  },
//点击发送验证码,获取手机号码,往后台发送数据
setVerify: function (e) {
    var linkTel = this.data.linkTel;
 
    var _Url = "申请下发短信的地址";//这个由后台或者你们公司的短信平台提供,一般是http://ip:prot/短信验证项目和具体地址
    var total_micro_second = 60 * 1000;    //表示60秒倒计时,想要变长就把60修改更大
    //验证码倒计时
    count_down(this, total_micro_second);
    wx.request({
      url: _Url,
      method: 'POST',
      headers: {
        'Content-Type': 'application/json'
      },
      data: [{
        agentLinktel: linkTel
      }],
      success: function (res) {
        if (res.data.code == "00") {
          wx.showModal({
            title: '提示',
            content: '发送验证码成功!',
            showCancel: false
          })
        }
      },
      fail: function (res) {
        console.log("error res=")
        console.log(res.data)
      }
    });
  }
//下面的代码在page({})外面
/* 毫秒级倒计时 */
function count_down(that, total_micro_second) {
  if (total_micro_second <= 0) {
    that.setData({
      VerifyCode: "重新发送"
    });
    // timeout则跳出递归
    return;
  }
 
  // 渲染倒计时时钟
  that.setData({
    VerifyCode: date_format(total_micro_second) + " 秒"
  });
 
  setTimeout(function () {
    // 放在最后--
    total_micro_second -= 10;
    count_down(that, total_micro_second);
  }, 10)
 
 
 
}
 
// 时间格式化输出,如03:25:19 86。每10ms都会调用一次
function date_format(micro_second) {
  // 秒数
  var second = Math.floor(micro_second / 1000);
  // 小时位
  var hr = Math.floor(second / 3600);
  // 分钟位
  var min = fill_zero_prefix(Math.floor((second - hr * 3600) / 60));
  // 秒位
  var sec = fill_zero_prefix((second - hr * 3600 - min * 60));// equal to => var sec = second % 60;
  // 毫秒位,保留2位
  var micro_sec = fill_zero_prefix(Math.floor((micro_second % 1000) / 10));
 
  return sec;
}
 
// 位数不足补零
function fill_zero_prefix(num) {
  return num < 10 ? "0" + num : num
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值