JS实现之用户注册协议倒计时

  • 要求:按钮显示5秒倒计时,5秒前禁点,5秒后可以点击按钮
  • 运行结果:
    5秒前
    在这里插入图片描述

5秒后
在这里插入图片描述

  • 思路
    • 开启禁用按钮属性disabled
    • 获取按钮元素
    • 开启倒计时函数setInterval
    • 调用函数,函数里包括变量自减,使用DOM对象修改时间,关闭按钮禁用属性
  • HTML代码:首先禁用按钮属性
    <textarea name="" id="" cols="30" rows="10">
        用户注册协议
        欢迎注册成为京东用户!在您注册过程中,您需要完成我们的注册流程并通过点击同意的形式在线签署以下协议,请您务必仔细阅读、充分理解协议中的条款内容后再点击同意.
    </textarea>
    <br>
    <!-- 设置禁用属性,开启按钮禁用 -->
    <button class="btn" disabled="true">我已经阅读用户协议(5)</button>
  • JS代码:
    注意:
    倒计时函数的调用函数两种方式,如果需要传参,可以在匿名函数里嵌套一个传参的函数,如果不需要传参,使用匿名函数更方便,这里的time是全局变量,函数里可以直接访问,所以可以不传参

写法1:这里演示的是需要传参时使用嵌套函数的写法

   <!-- 先获取元素,改变文字内容 -->
    <script>
        const btn = document.querySelector('.btn')
        let time = 5

        function daojishi(a) {
            // 用户一打开页面就要进行倒计时,注意书写顺序
            time--
            btn.innerHTML = `我已经阅读用户协议(${time})`

            //JS是单线程执行代码,会等待当前代码块执行完毕才会去执行其他任务。所以外部的 if 语句不会立即执行,因此不会检测到 time 值的变化。
            //因此将 if 语句放在函数内部,这样每次执行都会检查 time 值
            if (time===0) {
            //关闭倒计时
            clearInterval(tme) 
            btn.innerHTML = `我已经阅读用户协议` 
            //关闭禁用属性
            btn.disabled=false 
            }
        }
	
		// 倒计时函数写法1
        let tme = setInterval(function(){
            daojishi(time)
        }, 1000)

写法2:直接用匿名函数的写法
因为time在这里是全局变量,不需要传参,所以直接用匿名函数即可

        let tme = setInterval(function(){
            time--
            btn.innerHTML = `我已经阅读用户协议(${time})`
            if (time===0) {
            //关闭倒计时
            clearInterval(tme) 
            btn.innerHTML = `我已经阅读用户协议` 
            //关闭禁用属性
            btn.disabled=false 
        }}, 1000)
  • 注意:
    if语句写在函数外面,(倒计时函数后)没有反应
    JS是单线程执行代码,会等待当前代码块执行完毕才会去执行其他任务。外部的 if 语句不会立即执行,因此不会检测到 time 值的变化所以将 if 语句放在函数内部,这样每次执行都会检查 time 值
  • 6
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值