Vue实现手机号、验证码登录(60s禁用倒计时)


Posted in Vue.js onDecember 19, 2020

 最近在做一个Vue项目,前端通过手机号、验证码登录,获取验证码按钮需要设置60s倒计时(点击一次后,一分钟内不得再次点击)。先看一下效果图:

Vue实现手机号、验证码登录(60s禁用倒计时)

输入正确格式的手机号码后,“获取验证码”按钮方可点击;点击“获取验证码”后,按钮进入60s倒计时,效果图如下:

Vue实现手机号、验证码登录(60s禁用倒计时)

Vue实现手机号、验证码登录(60s禁用倒计时)

 效果图已经有了,接下来就上代码吧!

  • html
<el-button @click="getCode()" :class="{'disabled-style':getCodeBtnDisable}" :disabled="getCodeBtnDisable">{{codeBtnWord}}</el-button>
  • 数据data
data() {
     return {
        loginForm: {
            phoneNumber: '',
            verificationCode: '',
        },
        codeBtnWord: '获取验证码', // 获取验证码按钮文字
        waitTime:61, // 获取验证码按钮失效时间
    }
}
  • 计算属性computed
computed: {
    // 用于校验手机号码格式是否正确
    phoneNumberStyle(){
        let reg = /^1[3456789]\d{9}$/
        if(!reg.test(this.loginForm.phoneNumber)){
            return false
        }
        return true
    },
    // 控制获取验证码按钮是否可点击
    getCodeBtnDisable:{
        get(){
            if(this.waitTime == 61){
                if(this.loginForm.phoneNumber){
                    return false
                }
                return true
            }
            return true
        },
        // 注意:因为计算属性本身没有set方法,不支持在方法中进行修改,而下面我要进行这个操作,所以需要手动添加
        set(){} 
    }
}

关于上面给计算属性添加set方法,可以参照//3water.com/article/202496.htm

  •  css设置不可点击时置灰
.el-button.disabled-style {
    background-color: #EEEEEE;
    color: #CCCCCC;
}
  • mothods中添加获取验证码方法
getCode(){
    if(this.phoneNumberStyle){
        let params = {}
        params.phone = this.loginForm.phoneNumber
        // 调用获取短信验证码接口
        axios.post('/sendMessage',params).then(res=>{
            res = res.data
            if(res.status==200) {
                this.$message({
                    message: '验证码已发送,请稍候...',
                    type: 'success',
                    center:true
                })
            }
        })
        // 因为下面用到了定时器,需要保存this指向
        let that = this
        that.waitTime--
        that.getCodeBtnDisable = true
        this.codeBtnWord = `${this.waitTime}s 后重新获取`
        let timer = setInterval(function(){
            if(that.waitTime>1){
                that.waitTime--
                that.codeBtnWord = `${that.waitTime}s 后重新获取`
            }else{
                clearInterval(timer)
                that.codeBtnWord = '获取验证码'
                that.getCodeBtnDisable = false
                that.waitTime = 61
            }
        },1000)
    }
}

通过上面的代码,就可以实现了,如有错误,敬请指正!

以上就是Vue实现手机号、验证码登录(60s禁用倒计时)的详细内容,更多关于vue 手机号验证码登录的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
Vue项目利用axios请求接口下载excel
Nov 17 Vue.js
vue开发chrome插件,实现获取界面数据和保存到数据库功能
Dec 01 Vue.js
基于vue项目设置resolves.alias: '@'路径并适配webstorm
Dec 02 Vue.js
vue基于Echarts的拖拽数据可视化功能实现
Dec 04 Vue.js
基于vuex实现购物车功能
Jan 10 Vue.js
vue-video-player 断点续播的实现
Feb 01 Vue.js
vue实现无缝轮播效果(跑马灯)
May 14 Vue.js
详解Vue的options
May 15 Vue.js
Vue如何清空对象
Mar 03 Vue.js
在vue中import()语法不能传入变量的问题及解决
Apr 01 Vue.js
vue修饰符.capture和.self的区别
Apr 22 Vue.js
如何vue使用el-table遍历循环表头和表体数据
Apr 26 Vue.js
Vue——前端生成二维码的示例
Dec 19 #Vue.js
如何在vue中使用kindeditor富文本编辑器
Dec 19 #Vue.js
vue 在服务器端直接修改请求的接口地址
Dec 19 #Vue.js
vue 通过base64实现图片下载功能
Dec 19 #Vue.js
Vue中computed和watch有哪些区别
Dec 19 #Vue.js
Vue与React的区别和优势对比
Dec 18 #Vue.js
Vue实现指令式动态追加小球动画组件的步骤
Dec 18 #Vue.js
You might like
Cygwin中安装PHP方法步骤
2015/07/04 PHP
php加密解密字符串示例
2016/10/13 PHP
PHPstorm快捷键(分享)
2017/07/17 PHP
laravel 时间格式转时间戳的例子
2019/10/11 PHP
浅析PHP反序列化中过滤函数使用不当导致的对象注入问题
2020/02/15 PHP
jQuery判断当前点击的是第几个li的代码
2014/09/26 Javascript
JS实现文字向下滚动完整实例
2015/02/06 Javascript
js简单判断移动端系统的方法
2016/02/25 Javascript
限制只能输入数字的实现代码
2016/05/16 Javascript
jQuery选择器及jquery案例详解(必看)
2016/05/20 Javascript
浅谈js控制li标签排序问题 js调用php函数的方法
2016/10/16 Javascript
第一次接触Bootstrap框架
2016/10/24 Javascript
浅析JavaScript中break、continue和return的区别
2016/11/30 Javascript
实例讲解DataTables固定表格宽度(设置横向滚动条)
2017/07/11 Javascript
移动端触摸滑动插件swiper使用方法详解
2017/08/11 Javascript
js实现轮播图效果 z-index实现轮播图
2020/01/17 Javascript
Vue微信公众号网页分享的示例代码
2020/05/28 Javascript
详解ES6实现类的私有变量的几种写法
2021/02/10 Javascript
[35:39]完美世界DOTA2联赛PWL S2 FTD.C vs Rebirth 第二场 11.22
2020/11/24 DOTA
Python 正则表达式入门(中级篇)
2016/12/07 Python
python编程实现希尔排序
2017/04/13 Python
Django框架的中的setting.py文件说明详解
2018/10/15 Python
对Python中for复合语句的使用示例讲解
2018/11/01 Python
python3.x+pyqt5实现主窗口状态栏里(嵌入)显示进度条功能
2019/07/04 Python
Python创建数字列表的示例
2019/11/28 Python
利用python中的matplotlib打印混淆矩阵实例
2020/06/16 Python
python 基于PYMYSQL使用MYSQL数据库
2020/12/24 Python
canvas仿写贝塞尔曲线的示例代码
2017/12/29 HTML / CSS
洲际酒店集团大中华区:IHG中国
2016/08/17 全球购物
独特的礼品和创新的科技产品:The Grommet
2018/02/24 全球购物
澳大利亚在线时尚精品店:Hello Molly
2018/02/26 全球购物
项目申报专员岗位职责
2014/07/09 职场文书
班级出游活动计划书
2014/08/15 职场文书
财务工作个人总结
2015/02/27 职场文书
2015年社区卫生工作总结
2015/04/21 职场文书
python数据可视化使用pyfinance分析证券收益示例详解
2021/11/20 Python