vue清除定时器无效

代码如下,跳转页面后定时器依然在执行

created(){
    this.interval()
},
beforeDestroy () {
    console.log('清除定时器')
    clearInterval(this.interval)
},
methods: {
    interval(){
        setInterval(()=>{
            console.log('执行定时器')
            this.loadList()
        },3000)
    },
}
阅读 19.7k
2 个回答

清除的是定时器的引用,而不是方法

created(){
    this.interval()
},
beforeDestroy () {
    console.log('清除定时器')
    clearInterval(this._inter)
},
methods: {
    interval(){
        this._inter = setInterval(()=>{
            console.log('执行定时器')
            this.loadList()
        },3000)
    },
}

clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值。
你这个代码片段给它传的是一个function肯定不能清除啊

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题