vue页面定时刷新

首先页面主动刷新的方法,js和vue都给我们提供了方法。

//vue提供的方法
this.$router.go(0)

//js提供的方法
window.location.reload()

然后在一些需求下,用户不希望手动刷新就可以进行数据的更新(接口需要重新发请求去获取新的数据),这时候我们就可以设置定时器去实现,定时进行页面刷新的任务。

注意:如果定时任务短,使用以上两种刷新页面方法,用户可能会有很差的体验,因为刷新可能会有短暂白屏加载数据,建议定时任务长的时候使用。

data(){
   return{
     intervalId:null
   }
}
created(){
   this.dataRefreh();
},
unmounted() {
   // 销毁组件之前,清除计时器
   this.clear();
},
methods:{
   // 定时刷新数据函数
   dataRefreh() {
     // 计时器正在进行中,退出函数
     if (this.intervalId != null) {
        return;
     }
      // 计时器为空,操作
      this.intervalId = setInterval(() => {
         console.log("刷新" + new Date());
         this.dataRefreh();
         this.$router.go(0)  //每五分钟调用方法刷新一次页面,进行数据更新
        }, 300000);
      }, 
      // 停止定时器
      clear() {
        clearInterval(this.intervalId);//清除计时器
        this.intervalId = null; //设置为null
      },
}

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值