微信小程序项目实践之验证码倒计时功能


Posted in Javascript onJuly 18, 2018

效果如下:点击发送验证码按钮,按钮背景变色,不可点击,显示倒计时文字

微信小程序项目实践之验证码倒计时功能

首先js文件的data里面 声明一个变量用于表示当前是否可以点击,codeIsCanClick = true,  默认是可以点击的

写下界面代码:

wxml文件中

<view class='centerRow'>
 <view class='inputLabel'>动态码:</view>
 <input class='inputStyle' style="flex:1 " bindinput="bindKeyInput" placeholder="短信动态码" adjust-position='false'  confirm-type='search'></input>
 <button class="emailCode" hidden='{{!codeIsCanClick}}' size="mini" bindtap='clickCode'>获取动态码</button>
 <button class="emailCodeSend" hidden='{{codeIsCanClick}}' size="mini">{{last_time}}秒后重新发送</button>
</view>

 

对应样式 wxss文件:

.centerRow{
 display: flex;
 flex-direction: row;
 align-items: center;
 height: 44px;
 padding-left: 16px;
 padding-right: 16px;
 border-bottom: 1rpx solid #D9D9D9;
 border-top: 1rpx solid #D9D9D9;
}
.inputStyle{
 border-radius:4px;
 color:#D9D9D9;
 outline:0;
 padding-left: 4px;
 margin-left: 4px;
 margin-right: 20rpx;
 font-size: 14px;
}
.inputLabel{
 font-size: 16px;
 color: #33496D;
 width: 90px;
}
.emailCode{
 width: 118px;
 height: 28px;
 align-items: center;
 justify-content: center;
 display: flex;
 flex-direction: row;
 color:white;
 font-size: 14px;
 background-color: #50A2EC;
 border-radius: 14px;
}
.emailCodeSend{
 width: 118px;
 height: 28px;
 align-items: center;
 justify-content: center;
 display: flex;
 flex-direction: row;
 color:white;
 font-size: 14px;
 background-color: #B9DAF7;
 border-radius: 14px;
}

以上构成页面静态效果。

注意button有两个,分别对应的未点击和点击下的按钮样子,用js中的CodeIsCanClick控制显示隐藏

然后在js中写逻辑代码:

// 倒计时事件 单位s
var countdown = 10;
var settime = function (that) {
 if (countdown == 0) {
 that.setData({
  codeIsCanClick: true
 })
 countdown = 10;
 return;
 } else {
 that.setData({
  codeIsCanClick: false,
  last_time: countdown
 })
 countdown--;
 }
 setTimeout(function () {
 settime(that)
 }, 1000
 )
}
Page({
 /**
 * 页面的初始数据
 */
 data: {
 codeIsCanClick: true
 },
 /**
 * 点击验证码按钮
 */
 clickCode: function () {
 var that = this;
 settime(that)
 },

总结

以上所述是小编给大家介绍的微信小程序项目实践之验证码倒计时功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
优化innerHTML操作(提高代码执行效率)
Aug 20 Javascript
如何将JS的变量值传递给ASP变量
Dec 10 Javascript
JavaScript Serializer序列化时间处理示例
Jul 31 Javascript
基于JavaScript实现瀑布流布局(二)
Jan 26 Javascript
js字符串截取函数slice、substring和substr的比较
May 17 Javascript
在Javascript操作JSON对象,增加 删除 修改的简单实现
Jun 02 Javascript
react-router中的属性详解
Jun 01 Javascript
[js高手之路]设计模式系列课程-发布者,订阅者重构购物车的实例
Aug 29 Javascript
jquery中有哪些api jQuery主要API
Nov 20 jQuery
vue.js打包之后可能会遇到的坑!
Jun 03 Javascript
jQuery实现的淡入淡出图片轮播效果示例
Aug 29 jQuery
使用vue-router切换页面时,获取上一页url以及当前页面url的方法
May 06 Javascript
微信小程序日期选择器实例代码
Jul 18 #Javascript
JavaScript实现的反序列化json字符串操作示例
Jul 18 #Javascript
Angularjs实现多图片上传预览功能
Jul 18 #Javascript
JavaScript实现正则去除a标签并保留内容的方法【测试可用】
Jul 18 #Javascript
微信小程序scroll-x失效的完美解决方法
Jul 18 #Javascript
详解easyui基于 layui.laydate日期扩展组件
Jul 18 #Javascript
Vue无限滑动周选择日期的组件的示例代码
Jul 18 #Javascript
You might like
ThinkPHP 3.2.2实现事务操作的方法
2017/05/05 PHP
javascript 火狐(firefox)不显示本地图片问题解决
2008/07/05 Javascript
javascript 表格排序和表头浮动效果(扩展SortTable)
2009/04/07 Javascript
Ajax 数据请求的简单分析
2011/04/05 Javascript
javascript中JSON对象与JSON字符串相互转换实例
2015/07/11 Javascript
基于ExtJs在页面上window再调用Window的事件处理方法
2017/07/26 Javascript
详解Vuex管理登录状态
2017/11/13 Javascript
详解通过源码解析Node.js中cluster模块的主要功能实现
2018/05/16 Javascript
layui table 参数设置方法
2018/08/14 Javascript
开发用到的js封装方法(20种)
2018/10/12 Javascript
6行代码实现微信小程序页面返回顶部效果
2018/12/28 Javascript
原生JS检测CSS3动画是否结束的方法详解
2019/01/27 Javascript
react实现antd线上主题动态切换功能
2019/08/12 Javascript
vue路由 遍历生成复数router-link的例子
2019/10/30 Javascript
Node Express用法详解【安装、使用、路由、中间件、模板引擎等】
2020/05/13 Javascript
jquery html添加元素/删除元素操作实例详解
2020/05/20 jQuery
Python使用Scrapy保存控制台信息到文本解析
2017/12/27 Python
python实现遍历文件夹修改文件后缀
2018/08/28 Python
Python企业编码生成系统总体系统设计概述
2019/07/26 Python
python中删除某个元素的方法解析
2019/11/05 Python
django框架ModelForm组件用法详解
2019/12/11 Python
Django对接支付宝实现支付宝充值金币功能示例
2019/12/17 Python
Pycharm如何运行.py文件的方法步骤
2020/03/03 Python
Python django框架 web端视频加密的实例详解
2020/11/20 Python
使用CSS3代码绘制可爱的Hello Kitty猫
2016/08/03 HTML / CSS
基于css3仿造window7的开始菜单
2010/06/17 HTML / CSS
在对linux系统分区进行格式化时需要对磁盘簇(或i节点密度)的大小进行选择,请说明选择的原则
2012/01/13 面试题
创业计划书中要认真思考的问题
2013/12/28 职场文书
外企财务年会演讲稿
2014/01/03 职场文书
党校学习思想汇报
2014/01/06 职场文书
2014年迎新年活动方案
2014/02/19 职场文书
学习优秀党务工作者先进事迹材料思想报告
2014/09/17 职场文书
财务出纳岗位职责
2015/03/31 职场文书
倡议书的格式写法
2015/04/28 职场文书
CocosCreator ScrollView优化系列之分帧加载
2021/04/14 Python
python自动获取微信公众号最新文章的实现代码
2022/07/15 Python