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>
相关推荐
宇宙之一粟12 小时前
如何判断是时候离开了
后端·程序员
Doris_202312 小时前
eslint
前端·架构·前端框架
_喆13 小时前
视频切片上传
前端
前端拷贝猿13 小时前
微信绑定流程
前端
ZC跨境爬虫13 小时前
跟着 MDN 学CSS day_51:支持旧浏览器的布局策略
前端·css·html·tensorflow·媒体
Larcher13 小时前
从 0 到 1:Node.js 调用 AI API 的完整避坑指南
前端·javascript·css
ricardo197313 小时前
Web Worker + 时间切片:破解主线程阻塞的两种武器
前端·面试
wuhen_n13 小时前
LangGraph 入门:AI Agent 工作流可视化编排
前端·langchain·ai编程
wuhen_n13 小时前
LangChain Agent 优化:提升智能体决策准确率
前端·langchain·ai编程
夜空孤狼啸13 小时前
纯前端文档预览器--全能文件预览
前端