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 26 Vue.js
基于vue与element实现创建试卷相关功能(实例代码)
Dec 07 Vue.js
vue实现滚动鼠标滚轮切换页面
Dec 13 Vue.js
vue调用微信JSDK 扫一扫,相册等需要注意的事项
Jan 03 Vue.js
Vue项目打包部署到apache服务器的方法步骤
Feb 01 Vue.js
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 Vue.js
Vue3.0写自定义指令的简单步骤记录
Jun 27 Vue.js
vue使用echarts实现折线图
Mar 21 Vue.js
关于vue-router-link选择样式设置
Apr 30 Vue.js
VUE解决跨域问题Access to XMLHttpRequest at
May 06 Vue.js
vue ant design 封装弹窗表单的使用
Jun 01 Vue.js
VUE递归树形实现多级列表
Jul 15 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
DedeCMS 核心类TypeLink.class.php摘要笔记
2010/04/07 PHP
PHP之COOKIE支持详解
2010/09/20 PHP
PHP队列用法实例
2014/11/05 PHP
PHP入门教程之面向对象基本概念实例分析
2016/09/11 PHP
Javascript this指针
2009/07/30 Javascript
JS 动态获取节点代码innerHTML分析 [IE,FF]
2009/11/30 Javascript
javascript来定义类的规范小结
2010/11/19 Javascript
使用JavaScript动态设置样式实现代码(2)
2013/01/25 Javascript
js中文逗号转英文实现
2014/02/11 Javascript
javascript制作游戏开发碰撞检测的封装代码
2015/03/31 Javascript
jquery实现隐藏在左侧的弹性弹出菜单效果
2015/09/18 Javascript
Node.js文件操作方法汇总
2016/03/22 Javascript
Vue使用json-server进行后端数据模拟功能
2018/04/17 Javascript
vue使用中的内存泄漏【推荐】
2018/07/10 Javascript
JS实现倒计时图文效果
2018/11/17 Javascript
微信小程序实现基于三元运算验证手机号/姓名功能示例
2019/01/19 Javascript
在layui中对table中的数据进行判断(0、1)转换为提示信息的方法
2019/09/28 Javascript
js数据类型转换与流程控制操作实例分析
2019/12/18 Javascript
js模拟实现百度搜索
2020/06/28 Javascript
vue addRoutes路由动态加载操作
2020/08/04 Javascript
python实现的生成word文档功能示例
2019/08/23 Python
python+selenium 鼠标事件操作方法
2019/08/24 Python
详解vscode实现远程linux服务器上Python开发
2020/11/10 Python
下面代码从性能上考虑,有什么问题
2015/04/03 面试题
会计专业自荐信
2013/12/02 职场文书
超市促销活动方案
2014/03/05 职场文书
聚美优品广告词改编
2014/03/14 职场文书
电子商务求职信
2014/06/15 职场文书
镇政府副镇长群众路线专题民主生活会对照检查材料
2014/09/19 职场文书
优秀教研组申报材料
2014/12/26 职场文书
材料采购员岗位职责
2015/04/03 职场文书
2015年预算员工作总结
2015/05/14 职场文书
导游词之苏州阳澄湖
2019/11/15 职场文书
JS不要再到处使用绝对等于运算符了
2021/04/30 Javascript
python pygame入门教程
2021/06/01 Python
简单聊聊Vue中的计算属性和属性侦听
2021/10/05 Vue.js