欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-07-05 19:55:08
最近在做一个vue项目,前端通过手机号、验证码登录,获取验证码按钮需要设置60s倒计时(点击一次后,一分钟内不得再次点击)。先看一下效果图:输入正确格式的手机号码后,“获取验证码”按钮方可点击;点击“...

 最近在做一个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方法,可以参照

  •  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 手机号验证码登录的资料请关注其它相关文章!