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>
相关推荐
mCell2 小时前
使用 useSearchParams 同步 URL 和查询参数
前端·javascript·react.js
mCell3 小时前
前端路由详解:Hash vs History
前端·javascript·vue-router
海上彼尚3 小时前
无需绑卡的海外地图
前端·javascript·vue.js·node.js
1024肥宅4 小时前
手写 call、apply、bind 的实现
前端·javascript·ecmascript 6
Cosolar4 小时前
银河麒麟 / aarch64 系统:Docker + Docker Compose 完整安装教程
后端·程序员·架构
科杰智能制造4 小时前
纯前端html、js实现人脸检测和表情检测,可直接在浏览器使用
前端·javascript·html
每天吃饭的羊5 小时前
组件库的有些点击事件是name-click这是如何分装de
前端·javascript·vue.js
Coder-coco5 小时前
个人健康管理|基于springboot+vue+个人健康管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·mysql·论文
x***01065 小时前
SpringSecurity+jwt实现权限认证功能
android·前端·后端
1024肥宅5 小时前
防抖(Debounce)
前端·javascript·ecmascript 6