一、前言
-
setInterval不会清除定时器队列,每重复执行1次都会导致定时器叠加,会出现网页卡死现象。但是setTimeout是自带清除定时器的,两者结合使用将避免页面卡死。
-
离开页面时,通过生命周期onUnmounted钩子函数,清除定时器。
二、代码注释详解
xml
<template>
<div class="box">content</div>
</template>
<script setup>
import { ref, reactive, onUnmounted } from 'vue';
const data = reactive({
setIntervalFlag: null
})
// 获取数据
const getList = () => {
//这里是请求接口相关逻辑
}
// 首先获取数据一次数据
getList()
// 五秒取一次,轮询更新
data.setIntervalFlag = setInterval(() => {
// 嵌套定时器,利用setTimeout清除机制
setTimeout(() => {
getList()
}, 0)
}, 5000)
// 组件被卸载后清除定时器
onUnmounted(() => {
clearInterval(data.setIntervalFlag)
data.setIntervalFlag = null
})
// const { } = toRefs(data)
</script>
<style scoped lang="scss"></style>