vue页面中有一个计数器接口,需要在打开页面展示数据的时候反复调用该接口刷新数据

在 Vue 页面中,如果你有一个计数器接口,需要在打开页面时反复调用该接口来刷新数据,可以使用以下几种方法来实现这个需求:

方法 1:使用 setInterval 定时器

setInterval 可以在指定的时间间隔内反复调用函数。在 Vue 的生命周期钩子 mounted 中启动计时器,并在组件销毁时清除计时器。

<template>
  <div>
    <p>计数器值:{{ counter }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      counter: 0, // 用于存储计数器的值
      intervalId: null, // 用于存储定时器ID
    };
  },
  methods: {
    fetchCounterData() {
      this.$axios.get('/api/counter').then(response => {
        if (response.data && response.data.errCode === 0) {
          this.counter = response.data.counter; // 假设接口返回的数据中包含计数器值
        } else {
          this.$message.error('无法获取计数器数据');
        }
      }).catch(error => {
        this.$message.error('请求失败');
      });
    }
  },
  mounted() {
    // 页面加载后开始定时调用接口
    this.fetchCounterData(); // 立即调用一次
    this.intervalId = setInterval(this.fetchCounterData, 5000); // 每5秒调用一次
  },
  beforeDestroy() {
    // 组件销毁前清除定时器
    if (this.intervalId) {
      clearInterval(this.intervalId);
    }
  }
};
</script>

说明:

  1. fetchCounterData 方法:用于调用计数器接口并更新数据。
  2. setInterval:每隔 5 秒(5000 毫秒)调用 fetchCounterData 一次。
  3. mounted 钩子:组件加载后立即调用一次接口,并启动定时器。
  4. beforeDestroy 钩子:在组件销毁前清除定时器,防止内存泄漏。

方法 2:使用 watch 结合 setTimeout

如果你希望更加灵活地控制请求时间,可以使用 setTimeout 递归调用来代替 setInterval。这样你可以在每次请求完成后再决定何时进行下一次请求。

<template>
  <div>
    <p>计数器值:{{ counter }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      counter: 0,
    };
  },
  methods: {
    fetchCounterData() {
      this.$axios.get('/api/counter').then(response => {
        if (response.data && response.data.errCode === 0) {
          this.counter = response.data.counter;
        } else {
          this.$message.error('无法获取计数器数据');
        }
        this.scheduleNextFetch(); // 安排下一次请求
      }).catch(error => {
        this.$message.error('请求失败');
        this.scheduleNextFetch(); // 即使失败也安排下一次请求
      });
    },
    scheduleNextFetch() {
      setTimeout(this.fetchCounterData, 5000); // 每5秒调用一次
    }
  },
  mounted() {
    this.fetchCounterData(); // 页面加载后立即调用一次
  }
};
</script>

说明:

  1. setTimeout:每次请求完成后调用 scheduleNextFetch,安排下一次请求。这可以避免当请求处理时间不定时产生的重复请求。
  2. 失败重试:即使请求失败,也会安排下一次请求,从而确保计数器继续更新。

方法 3:使用 Vue 3 的 Composition APIwatchEffect

在 Vue 3 中,可以使用 watchEffect 来监听某些状态的变化,并基于这些状态触发接口调用。

<template>
  <div>
    <p>计数器值:{{ counter }}</p>
  </div>
</template>

<script>
import { ref, onMounted, onUnmounted } from 'vue';

export default {
  setup() {
    const counter = ref(0);
    let intervalId = null;

    const fetchCounterData = () => {
      axios.get('/api/counter').then(response => {
        if (response.data && response.data.errCode === 0) {
          counter.value = response.data.counter;
        } else {
          console.error('无法获取计数器数据');
        }
      }).catch(error => {
        console.error('请求失败');
      });
    };

    onMounted(() => {
      fetchCounterData();
      intervalId = setInterval(fetchCounterData, 5000);
    });

    onUnmounted(() => {
      if (intervalId) {
        clearInterval(intervalId);
      }
    });

    return {
      counter
    };
  }
};
</script>

说明:

  1. onMountedonUnmounted:这两个钩子函数用于在组件加载时启动定时器,并在组件销毁时清除定时器。
  2. ref:用于声明响应式的状态变量 counter

总结

  • setInterval:适合定期调用接口,无需考虑每次请求的完成时间。
  • setTimeout:适合需要精确控制请求时间间隔的情况,尤其是在处理时间不定或需要根据请求结果调整时间时。
  • Vue 3:使用 Composition API 结合 onMountedonUnmounted 实现计数器更新,代码更加模块化和灵活。

根据你的需求选择合适的实现方式。


a. 尝试在失败情况下添加重试逻辑。

b. 在页面离开时暂停计数器更新,回到页面时重新启动。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值