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>
相关推荐
codingWhat1 分钟前
介绍一个手势识别库——AlloyFinger
前端·javascript·vue.js
远山枫谷13 分钟前
一文理清页面/组件通信与 Store 全局状态管理
前端·微信小程序
codingWhat13 分钟前
手撸一个「能打」的 React Table 组件
前端·javascript·react.js
HelloReader14 分钟前
Tauri 应用安全从开发到发布的威胁防御指南
前端
bluceli14 分钟前
WebAssembly实战指南:将高性能计算带入浏览器
前端·webassembly
yuki_uix15 分钟前
Object.entries:优雅处理 Object 的瑞士军刀
前端·javascript
奇迹_h4 小时前
打造你的HTML5打地鼠游戏:零基础入门实践
前端
SuperEugene5 小时前
Vue生态精选篇:Element Plus 的“企业后台常用组件”用法扫盲
前端·vue.js·面试
Neptune15 小时前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
贾铭5 小时前
如何实现一个网页版的剪映(三)使用fabric.js绘制时间轴
前端·后端