vue实现某个页面强制刷新router-view

1、首先需要修改App.vue

<template>
  <div id="app">
    <router-view v-if="isRouterAlive" />
  </div>
</template>

<script>
export default {
  name: "App",
  provide() {
    return {
      reload: this.reload,
    };
  },
  data() {
    return {
      isRouterAlive: true,
    };
  },
  methods: {
    reload() {
      this.isRouterAlive = false;
      this.$nextTick(() => {
        this.isRouterAlive = true;
      });
    },
  },
};
</script>

2. 到需要刷新的页面进行引用,使用inject导入引用reload,然后直接调用即可

<template>
  <div></div>
</template>

<script>
export default {
  inject: ['reload'],
  data() {
    return {},
  },
  created() {
    this.reload();
  },
  methods: {},
}
</script>

Published by

风君子

独自遨游何稽首 揭天掀地慰生平

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注