打开一个页面,数据是接口轮询返回的,还可以修改属性,如何在编辑时暂停轮询

文章介绍了如何利用Vueuse库中的useIntervalFn函数封装一个轮询请求的方法,该方法接受一个获取数据的函数和一个布尔值,当布尔值为真时启动轮询,同时展示了如何用watch进行监听和控制轮询的启停。
摘要由CSDN通过智能技术生成

 使用 @vueuse/core封装的方法,传递一个函数,监听一个boolean值

import { MaybeComputedRef, resolveRef, useIntervalFn } from '@vueuse/core';
import { watch } from 'vue';

type RequetFunction = (...args: any[]) => any;

/**
 * 卡片轮询
 * @param reqFn 获取数据函数
 * @param isInterval 轮询开始/停止
 * @param interval 间隔 @default 5000
 */
const usePoolingReq = (
  reqFn: RequetFunction,
  isInterval: MaybeComputedRef<boolean> = true,
  interval = 3000,
) => {
  const isIntervalCpt = resolveRef(isInterval);

  const { pause, resume, isActive } = useIntervalFn(reqFn, interval, {
    immediateCallback: true,
  });

  watch(
    isIntervalCpt,
    (val) => {
      if (val) {
        // eslint-disable-next-line no-unused-expressions
        !isActive.value && resume();
      } else {
        pause();
      }
    },
    { immediate: true },
  );
};

export default usePoolingReq;
const isInterval = ref(true);
usePoolingReq(getParamsData, () => isInterval.value);
 // 取消时
isInterval.value=true

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值