vue+elementUI 发送手机验证码button倒计时禁用

本文介绍了如何在Vue.js项目中结合ElementUI库,实现发送手机验证码后的按钮禁用并启动倒计时功能。详细讨论了相关组件的使用和JavaScript逻辑,帮助开发者创建更友好的用户体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

按钮标签:

<el-button
    type="primary"
    @click="getVerify"
    style="width:175px;"
    :disabled="disabled=!show"
>
<span v-show="show">获取验证码</span>
<span v-show="!show" class="count">{{count}} s</span>
</el-button>

script:

<script>
export default {
    data() {
        return {
            show: true,
            count: "", // 初始化次数
            timer: null
         }
    },
    methods: {
        getVerify() {
            // 验证手机号
            if (this.checkPhone() == false) {
                return false;
            } else {
                const TIME_COUNT = 60; //更改倒计时时间
                if (!this.timer) {
                    this.count = TIME_COUNT;
                    this.show = false;
                    this.timer = setInterval(() => {
                        if (this.count > 0 && this.count <= TIME_COUNT) {
                            this.count--;
                        } else {
                            this.show = true;
                            clearInterval(this.timer); // 清除定时器
                            this.timer = null;
                        }
                    }, 1000);
                }
            }
        },
        checkPhone() {
            let phone = this.form.phone;
            if (!/^1[3456789]\d{9}$/.test(phone)) {
                this.$message.error("请填写正确的手机号");
                return false;
            }
        }
    }
}
</script>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值