为什么我的倒数功能会快速运行?

问题描述 投票:1回答:2

我在vue.js中有一个倒计时功能,更新速度太快。

这里是数据部分

data() {
        return {
            selected: [],
            countdown: timerLimit
        }

下面是倒计时方法

countdownTimer() {
        this.countdown = 60;
            var downloadTimer = setInterval(() => {
            if(this.countdown <= 0){
                clearInterval(downloadTimer);
                if (this.thisUser.captain) {
                        Store.submitTurnEnd();
                    }
            }
            this.countdown -= 1
            console.log(this.countdown)
            }, 1000);
        },

以上被召唤的人。但是,我注意到单击几次后,通常速度太快。我认为我需要更新数据部分,但不确定如何更新。

感谢您的帮助。

javascript vue.js countdowntimer
2个回答
0
投票

您可以尝试这个。

new Vue({
  el: "#app",
  data: {
    counter: 5
  },
  methods: {
    countdownTimer: function() {
        let interval;

        interval = setInterval(() => {
            if (this.counter > 0) {
                this.counter = this.counter - 1;
            } else {
                clearInterval(interval);
                // Do whatever you want to do
            }
        }, 1000);
    }
  }
})

模板部分是

<div id="app">
  <h2>Countdown:</h2>
  <h1>{{ counter }}</h1>
  <button v-on:click="countdownTimer">Start</button>
</div>

0
投票

它可以帮助您在数据中添加另一个变量:

data() {
        return {
            selected: [],
            countdown: timerLimit,
            isCountdownActive: false
}

方法:

countdownTimer() {
        // exit method if it is active
        if(this.isCountdownActive == true) return;

        // first time set ttrue
        this.isCountdownActive = true

        this.countdown = 60;
            var downloadTimer = setInterval(() => {
            if(this.countdown <= 0){
                clearInterval(downloadTimer);
                if (this.thisUser.captain) {
                        Store.submitTurnEnd();
                }

                // On exit interval, restart to false 
                this.isCountdownActive = false
            }
            this.countdown -= 1
            console.log(this.countdown)
            }, 1000);
},
© www.soinside.com 2019 - 2024. All rights reserved.