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 组件注册
Nov 20 Vue.js
vue单元格多列合并的实现
Nov 26 Vue.js
Vue+element-ui添加自定义右键菜单的方法示例
Dec 08 Vue.js
vue中封装axios并实现api接口的统一管理
Dec 25 Vue.js
SpringBoot+Vue 前后端合并部署的配置方法
Dec 30 Vue.js
vue+flask实现视频合成功能(拖拽上传)
Mar 04 Vue.js
vue响应式原理与双向数据的深入解析
Jun 04 Vue.js
解决Vue+SpringBoot+Shiro跨域问题
Jun 09 Vue.js
Vue h函数的使用详解
Feb 18 Vue.js
vue修饰符.capture和.self的区别
Apr 22 Vue.js
使用vuex-persistedstate本地存储vuex
Apr 29 Vue.js
vue3不同环境下实现配置代理
May 25 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
MOTOROLA 摩托罗拉 MODEL 66-XI五灯中波收音机
2021/03/02 无线电
2021年最新CPU天梯图
2021/03/04 数码科技
smarty section简介与用法分析
2008/10/03 PHP
php 图片上传类代码
2009/07/17 PHP
php setcookie(name, value, expires, path, domain, secure) 参数详解
2013/06/28 PHP
ThinkPHP实现带验证码的文件上传功能实例
2014/11/01 PHP
php发送html格式文本邮件的方法
2015/06/10 PHP
如何通过View::first使用Laravel Blade的动态模板详解
2017/09/21 PHP
php学习笔记之字符串常见操作总结
2019/07/16 PHP
PHP的new static和new self的区别与使用
2019/11/27 PHP
通过JS 获取Mouse Position(鼠标坐标)的代码
2009/09/21 Javascript
js针对ip地址、子网掩码、网关的逻辑性判断
2016/01/06 Javascript
使用jQuery调用XML实现无刷新即时聊天
2016/08/07 Javascript
纯JS实现简单的日历
2017/06/26 Javascript
关于微信小程序bug记录与解决方法
2018/08/15 Javascript
基于Node.js搭建hexo博客过程详解
2019/06/25 Javascript
vue路由切换之淡入淡出的简单实现
2019/10/31 Javascript
vue微信分享插件使用方法详解
2020/02/18 Javascript
jQuery实现颜色打字机的完整代码
2020/03/19 jQuery
在JavaScript中查找字符串中最长单词的三种方法(推荐)
2021/01/18 Javascript
Vue使用Ref跨层级获取组件的步骤
2021/01/25 Vue.js
ES6的循环与可迭代对象示例详解
2021/01/31 Javascript
[01:41]DOTA2超级联赛专访YYF 称一辈子难忘TI2
2013/05/28 DOTA
[46:42]DOTA2-DPC中国联赛正赛 Aster vs Magma BO3 第二场 3月5日
2021/03/11 DOTA
解决python字典对值(值为列表)赋值出现重复的问题
2019/01/20 Python
python pandas移动窗口函数rolling的用法
2020/02/29 Python
Python API len函数操作过程解析
2020/03/05 Python
Python+MySQL随机试卷及答案生成程序的示例代码
2021/02/01 Python
舞蹈比赛获奖感言
2014/02/04 职场文书
餐饮收银员岗位职责
2014/02/07 职场文书
工程安全员岗位职责
2014/03/09 职场文书
学校火灾防控方案
2014/06/09 职场文书
房屋过户委托书范本
2014/10/07 职场文书
乡镇一岗双责责任书
2015/01/29 职场文书
工程移交协议书
2016/03/24 职场文书
zabbix配置nginx监控的实现
2022/05/25 Servers