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的tree组件
Dec 03 Vue.js
vue表单验证之禁止input输入框输入空格
Dec 03 Vue.js
vue 基于abstract 路由模式 实现页面内嵌的示例代码
Dec 14 Vue.js
vue3.0实现插件封装
Dec 14 Vue.js
Vue-router中hash模式与history模式的区别详解
Dec 15 Vue.js
vue图片裁剪插件vue-cropper使用方法详解
Dec 16 Vue.js
学习 Vue.js 遇到的那些坑
Feb 02 Vue.js
vue前端工程的搭建
Mar 31 Vue.js
vue实力踩坑之push当前页无效
Apr 10 Vue.js
vue配置型表格基于el-table拓展之table-plus组件
Apr 12 Vue.js
vue2的 router在使用过程中遇到的一些问题
Apr 13 Vue.js
vue使用element-ui按需引入
May 20 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
解析在PHP中使用mysqli扩展库对mysql的操作
2013/07/03 PHP
CodeIgniter基本配置详细介绍
2013/11/12 PHP
Destoon模板制作简明教程
2014/06/20 PHP
PHP防止刷新重复提交页面的示例代码
2015/11/11 PHP
PHP中读取文件的几个方法总结(推荐)
2016/06/03 PHP
PHP中Session ID的实现原理实例分析
2019/08/17 PHP
PHP实现抽奖功能实例代码
2020/06/30 PHP
热点新闻滚动特效的js代码
2013/08/17 Javascript
js实现动态添加、删除行、onkeyup表格求和示例
2013/08/18 Javascript
javascript获取选中的文本的方法代码
2013/10/30 Javascript
javascript跨域方法、原理以及出现问题解决方法(详解)
2015/08/06 Javascript
web前端开发JQuery常用实例代码片段(50个)
2015/08/28 Javascript
jquery实现的点击翻书效果代码
2015/11/04 Javascript
轻松实现javascript数据双向绑定
2015/11/11 Javascript
jQuery实现的AJAX简单弹出层效果代码
2015/11/26 Javascript
jQuery点击改变class并toggle及toggleClass()方法定义用法
2015/12/11 Javascript
最好用的Bootstrap fileinput.js文件上传组件
2016/12/12 Javascript
BootStrapValidator初使用教程详解
2017/02/10 Javascript
Ionic项目中Native Camera的使用方法
2017/06/07 Javascript
深入浅析Node.js单线程模型
2017/07/10 Javascript
jQuery EasyUI 选项卡面板tabs的使用实例讲解
2017/12/25 jQuery
angular6 填坑之sdk的方法
2018/12/27 Javascript
详解Puppeteer前端自动化测试实践
2019/02/21 Javascript
vue计算属性无法监听到数组内部变化的解决方案
2019/11/06 Javascript
原生js+canvas实现下雪效果
2020/08/02 Javascript
如何使用pyinstaller打包32位的exe程序
2019/05/26 Python
is_file和file_exists效率比较
2021/03/14 PHP
使用html5 canvas绘制圆环动效
2019/06/03 HTML / CSS
关于webview适配H5上传照片或者视频文件的方法
2020/11/04 HTML / CSS
美国专营婴幼儿用品的购物网站:buybuy BABY
2017/01/01 全球购物
给校长的建议书400字
2014/05/15 职场文书
光棍节联谊晚会活动策划书
2014/10/10 职场文书
幼儿园中秋节活动总结
2015/03/23 职场文书
离婚案件答辩状
2015/05/22 职场文书
学生会部长竞选稿
2015/11/19 职场文书
85句关于理想的名言警句大全
2019/08/22 职场文书