VUE轮询

一、前言

  • 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>
相关推荐
掘金安东尼7 分钟前
⏰前端周刊第 454 期(2026年2月16日-2月22日)
前端·javascript·面试
掘金安东尼20 分钟前
⏰前端周刊第 453 期(2026年2月9日-2月15日)
前端·javascript·面试
Amumu1213823 分钟前
CSS进阶导读
前端·css
anyup27 分钟前
uniapp开发的鸿蒙应用上架后,竟然月入4000+
前端·vue.js·harmonyos
无尽的沉默30 分钟前
使用Thymeleaf配置国际化页面(语言切换)
前端·spring boot
SimonKing38 分钟前
跨越数据孤岛!SpringBoot使用JDBC调用Calcite联邦查询实战
java·后端·程序员
代码老中医43 分钟前
接手老项目的一个月,我重构了那个2000行的“祖传”React组件
前端
用户83040713057011 小时前
外链跳转后首页参数丢失:从缓存兜底到页面重加载的完整方案
vue.js
用户83040713057011 小时前
路由传参刷新丢失问题:三种解决方案与最佳实践
前端
从文处安1 小时前
「前端何去何从」高效提示词(prompts):前端开发者的AI协作指南
前端·aigc