zl程序教程

您现在的位置是:首页 >  前端

当前栏目

解决在JS中阻止定时器“重复”开启问题、Vue中定时器的使用

JSVue 解决 开启 重复 定时器 阻止 问题
2023-09-14 09:07:25 时间

1、问题描述

在一些需求开发中、需要设定软件提供服务的时间段(营业时间)。这时可以选择定时器来实现、可以选择让定时器每隔一段时间检测当前时间是否在服务时间。到达服务时间、进入服务状态。未到服务时间、进入非服务时间段。可能会遇到的问题? 当进行不同服务的切换、退出等操作 需要多次经过定时器的方法时、造成的后果就是定时器开启多次。导致页面功能混乱。怎样解决这一个问题呢? 方法很简单、就是在开启定时器之前、先将上一个开启的定时器关闭(直接在开启定时器的代码之前、编写清除上一次设置的定时器)。这样、无论多少次经过开启定时器的方法、都始终能保持只有一个定时器在工作。

2、模拟一个场景

2.1 假如多次调用(或者业务流程必须经过)开启定时器的方法、就会造成定时器开启多次

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8" />
    <title>定时器</title>
    <!-- 引入vue -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>

<body>
    <div id="App">
        <h1>当前num:{{num}}</h1>
        <button @click="startTimer()">点我开启定时器</button>
        <button @click="StopTimer()">点我关闭定时器</button>

    </div>
    <script type="text/javascript">
        Vue.config.productionTip = false  //设置为 false 以阻止 vue 在启动时生成生产提示
        let timerd = null

        //创建Vue实例
        new Vue({
            el: '#App',
            data: {
                value: "Vue",
                newTime: '',
                num: 1,
                // timerd: ''

            },
            methods: {

                StopTimer() {
                    console.log("当前关闭的定时器的值:" + timerd)
                    clearInterval(timerd)
                },
                startTimer() {
                    // clearInterval(timerd)
                    console.log(timerd)
                    console.error("开启了定时器")
                    timerd = setInterval(() => {
                        this.num++
                    }, 1000)

                    console.log("当前定时器的值:" + timerd)
                }
            },
        })
    </script>

</body>

</html>

2.2 测试效果

在这里插入图片描述

2.3 只需要稍微改动、在开启定时器之前、关闭上一个定时器

在这里插入图片描述

2.4 实现效果

在这里插入图片描述

3、定时器的基本使用常识

  • setInterval() :按照指定的周期(以毫秒计)来调用函数或计算表达式。方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。
  • setTimeout() :在指定的毫秒数后调用函数或计算表达式。

3.1 setInterval()

  • 语法:setInterval(code,millisec,lang)
参数描述
code必需。要调用的函数或要执行的代码串。
millisec必须。周期性执行或调用 code 之间的时间间隔,以毫秒计。
lang可选。 JScript、VBScript 、 JavaScript

3.2 setTimeout()

  • 语法:setTimeout(code,millisec,lang)
参数描述
code必需。要调用的函数后要执行的 JavaScript 代码串。
millisec必需。在执行代码前需等待的毫秒数。
lang可选。脚本语言可以是:JScript 、 VBScript 、JavaScript

4、模拟定时器的开关

4.1 代码实例

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8" />
    <title>定时器</title>
    <!-- 引入vue -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>

<body>
    <div id="App">
        <h1>当前num:{{num}}</h1>
        <button @click="startTimer()">点我开启定时器</button>
        <button @click="StopTimer()">点我关闭定时器</button>

    </div>
    <script type="text/javascript">
        Vue.config.productionTip = false  //设置为 false 以阻止 vue 在启动时生成生产提示
        let timerd = null

        //创建Vue实例
        new Vue({
            el: '#App',
            data: {
                value: "Vue",
                newTime: '',
                num: 1,
                // timerd: ''

            },
            methods: {

                StopTimer() {
                    console.log("当前关闭的定时器的值:" + timerd)
                    clearInterval(timerd)
                },
                startTimer() {                
                    console.error("开启了定时器")
                    timerd = setInterval(() => {
                        this.num++
                    }, 1000)

                    console.log("当前定时器的值:" + timerd)
                }
            },
        })
    </script>

</body>

</html>

4.2 测试效果

在这里插入图片描述
在这里插入图片描述