如何实时轮询查询数据状态改变

需求:
进来查询接口,状态(3种:待投决,已投决,已结束),除了已结束状态都需要每3秒轮询一次,直到离开页面或者状态变为已结束才结束轮询

created() {
 // 查询
   this.query(this.id)   
},
query(id) {
  joinDetail({id:id}).then(res =>{
    if(res.status == true) {
       // 赋值……
       this.item = res.body
       this.firstState = this.item.userVoteStatus.desc
       // 判断状态:第一次进来除了已结束都需要轮询
       if(this.item.userVoteStatus.desc === '待投决' || this.item.userVoteStatus.desc === "已投决") {
           this.always()
       }
    }
  })
},
always() {
  //轮询接口
  let that = this
  that.timers = setInterval(() => {
     // 当状态变为已结束时,就停止轮询
    if (this.item.userVoteStatus.desc === '已结束'){
         clearInterval(this.timers)
    //否则则继续轮询
    } else if (this.item.userVoteStatus.desc === "待投决" || this.item.userVoteStatus.desc === "已投决") {
         that.queryVoteNum()
    }
  }, 3000);
},
// 实时查询投票人数等等的变化  --- 轮询
queryVoteNum() {
  let that = this
  let params = {id:that.id}
  publishDetail(params).then((res)=>{
    if(res.status == true) {
    // 赋值
      …………
      that.item.status = res.body.status
      that.item.topics = JSON.parse(JSON.stringify(res.body.topics))
    }
  })
  .catch(function (err) {console.log(err)});
},
// 在vue实例销毁前调用(类似跳转路由调用)
beforeDestroy(){
  clearInterval(this.timers)
},
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值