vue项目使用定时器每隔几秒请求一次接口

12 篇文章 0 订阅

vue.js项目,每隔5秒请求一次接口,接口有返回则停止请求,没有返回继续请求。
先看两种定时器

// 每隔设定时间调用一次函数
setInterval(function(){}, milliseconds) 

 //设定时间后只执行函数一次
setTimeout(function(){}, milliseconds) 

注意:单纯的使用setInterval会导致页面卡死!
由于setInterval不会清除定时器队列,每重复执行1次都会导致定时器叠加,最终卡死网页。 但是setTimeout是自带清除定时器的,因此正确解决方法如下:

    window.setInterval(() => {
        setTimeout(fun, 0)
        }, 30000)

setInterval必须放在外层,内层配合setTimeout,便可以无限次调用接口

回到要解决的问题,如何在得到数据后停止定时器?

// 如methods里定义的点击方法
 methods: {
    click () {
        let  timer = setInterval(() => {
        this.fun(timer)
         }, 5000)
      },
     fun (timer) {
         setTimeout(()=>{
          // 这里ajax 请求的代码片段和判断是否停止定时器
          ..........
          // 如需要停止定时器,只需加入以下:
           clearInterval(timer)
          }, 0)
     }
    }

如果增加在请求n次后还是没有结果的话,就停止请求,只需在data里面定义一个计数字段 i 默认为 0,setTimeout内请求时执行 ++i ,后续判断即可

  • 23
    点赞
  • 77
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js项目中,你可以使用定时器来实现每隔5执行一次的功能。然而,需要注意的是,单纯使用setInterval会导致页面卡死的问题。因为setInterval不会清除定时器队列,每次执行都会导致定时器叠加,最终导致页面卡死。为了避免这个问题,你可以使用setTimeout来清除定时器。以下是一个正确的解决方法: ```javascript let timer = null; function executeEvery5Seconds() { // 执行你的代码逻辑 // ... // 设置下一次执行 timer = setTimeout(executeEvery5Seconds, 5000); } // 在Vue组件中调用定时器 mounted() { timer = setTimeout(executeEvery5Seconds, 5000); }, // 在Vue组件销毁时清除定时器 beforeDestroy() { clearTimeout(timer); } ``` 这样,你就可以在Vue.js项目中实现每隔5执行一次的功能,同时避免了页面卡死的问题。 #### 引用[.reference_title] - *1* *2* [vue项目使用定时器每隔几秒请求一次接口](https://blog.csdn.net/qq_39840470/article/details/104635153)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [vue项目使用定时器每隔几秒运行一次某方法](https://blog.csdn.net/wulikunbing/article/details/127746447)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值