vue中轮询:推荐 vue-request、@vueuse/core、rxjs

一、vue-request(专为 Vue 设计的请求库)

vue-request 是 Vue 生态中专注于请求管理的库,内置轮询功能,核心优势:

  • 自动处理请求时序:确保上一次请求完成后才发起下一次,避免重叠(类似 setTimeout 递归的效果,但无需手动实现)。
  • 与 Vue 响应式深度集成:轮询的状态(loading、data、error)直接通过响应式变量暴露,可在模板中直接使用。
  • 生命周期自动管理:组件卸载时自动停止轮询,无需手动清理。
  • 丰富的轮询控制:支持 pollingInterval(轮询间隔)、pollingWhenHidden(页面隐藏时是否继续)、manual(手动触发)等配置。
javascript 复制代码
<script setup>
import { useRequest } from 'vue-request';
import { getMessage } from './api';

// 轮询请求:每 3 秒获取一次消息
const { data, loading, run, cancel } = useRequest(
  () => getMessage(),
  {
    pollingInterval: 3000, // 轮询间隔
    pollingWhenHidden: false, // 页面隐藏时暂停
    manual: false, // 自动开始轮询
  }
);
</script>

二、@vueuse/core(Vue 工具函数集合)

@vueuse/core 提供了 useIntervalFn 等工具,专为 Vue 场景封装定时器,优势:

  • 自动清理定时器:基于 Vue 生命周期,组件卸载时自动清除,避免内存泄漏。
  • 响应式控制:可通过 ref 动态控制轮询的开始 / 暂停(isActive)、间隔时间(interval)。
  • 与其他工具联动:可结合 useDocumentVisibility 实现「页面可见时才轮询」等高级逻辑。
javascript 复制代码
<script setup>
import { useIntervalFn, useDocumentVisibility } from '@vueuse/core';
import { getMessage } from './api';

// 页面可见性(用于控制轮询)
const visibility = useDocumentVisibility();
const isVisible = computed(() => visibility.value !== 'hidden');

// 轮询逻辑
const { start, stop, isActive } = useIntervalFn(
  async () => {
    // 仅在页面可见时执行请求
    if (isVisible.value) {
      await getMessage();
    }
  },
  3000, // 间隔 3 秒
  { immediate: true } // 立即开始
);
</script>

三、rxjs(响应式编程库)

rxjs 基于「流」的概念处理异步逻辑,适合复杂轮询场景,优势:

  • 强大的流控制:通过 interval、switchMap 等操作符,轻松实现「上一次请求未完成则忽略下一次」「错误重试」「动态调整间隔」等逻辑。
  • 声明式编程:用链式调用描述轮询逻辑,可读性高,避免回调嵌套。
  • 与 Vue 集成:可通过 toRef 将流转换为 Vue 响应式数据,在组件中使用。
javascript 复制代码
<script setup>
import { interval, of } from 'rxjs';
import { switchMap, retry, filter } from 'rxjs/operators';
import { getMessage } from './api';
import { toRef } from 'vue';

// 轮询流:每 3 秒一次,请求失败重试 2 次,只在有数据时更新
const message$ = interval(3000).pipe(
  switchMap(() => getMessage().pipe(retry(2))), // switchMap 确保只处理最新请求
  filter(Boolean) // 过滤空数据
);

// 转换为 Vue 响应式数据
const message = toRef(message$);
</script>
相关推荐
Jul1en_12 分钟前
Claude 迁移 Codex 工作流迁移与更新
java·服务器·前端·后端·ai编程
Heo14 分钟前
14_React 中的更新队列 updateQueue
前端·javascript·面试
前端 贾公子21 分钟前
解决浏览器端 globalThis is not defined 报错
前端·javascript·vue.js
宁雨桥23 分钟前
前端与AI结合实战分享
前端·人工智能
之歆42 分钟前
DAY12_CSS3选择器全攻略 + 盒子新特性完全指南(下)
前端·javascript·css3
kyriewen1144 分钟前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
开发语言·前端·javascript·设计模式·ecmascript
光影少年1 小时前
react函数组件、类组件、纯组件、受控/非受控组件
前端·react.js·掘金·金石计划
程序员包打听1 小时前
MoonBit 是什么?给第一次听说这门语言的你
前端·后端
Rkgua1 小时前
CSS动画效果
前端·css
Rkgua1 小时前
Flexbox 与 Grid 布局
前端·css