【vue/cli3+】路由不变的情况下,刷新页面

【vue/cli3+】路由不变的情况下,刷新页面

前言

在vue写的后台管理项目中,经常会有增、删、改、查的操作,这些操作只是跟用接口跟后台交互下,既然用接口交互,那肯定就是axios的异步请求,那么就是说后台数据发生了改变,但是前台的数据并没有实时的更新(每次操作完后台把列表数据重新返给你例外,但是这样的话每次交互的数据量就偏大了),所以就有了动态路由。在使用动态路由配置/detail/:id这样的情况下,由于router-view是复用的,单纯的改变id的值并不会刷新router-view所以就要想一个办法,让后台执行完操作后,给前台返一个操作结果,然后前台手动刷新页面,一开始我想到的是用window.location.reload()或者this.$router.go(0)这两个方法,但是后来发现这两个方法消耗都很大,用户体验并不太好,违背了vueRouter的初衷,所以就放弃了。看了下别人的做法,整理下面两种方法:

第一种:中转站的方式

用一个空白组件在每次操作之后进行跳转,相当于Nginx反向代理一样。意思就是让每次操作完成以后,都让路由跳转到这个中转站页面,然后这个页面获取到进来路由的路径再返回去就可以了。这种方式如果说你的路由是显性的,就是直接显示在浏览器地址栏,你会发现,一直在换,而我目前使用的则是第二种方式。

第二种:provide / inject 的方式

这种方式与Spring boot中的切面/注解有点类似,就是通过provideApp.vue为所有子组件注入一个reload方法,然后在需要使用的页面,通过inject注入即可、请看代码:

<template>
  <div id="app">
    <router-view v-if="isRouterAlive"></router-view>
  </div>
</template>
 
<script>
export default {
  name: "App",
  provide() {
    return {
      reload: this.reload
    };
  },
  data() {
    return {
      isRouterAlive: true
    }
  },
  methods: {
    reload() {
      this.isRouterAlive = false;
      this.$nextTick(function() {
        this.isRouterAlive = true;
      });
    }
  }
};
</script>

在需要调用的子页面:

<template>
   <!--你的子页面布局-->
</template>

<script>
export default {
    //...
    inject: ['reload'],
    methods: {
        delData(){
            //在axios成功的回调里面
            this.reload();
        }
    }
    //...
}
</script>

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我的支持。😘✔

当然也可以去我的博客梦想小筑与我交流。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3中,可以使用`<router-view>`组件来渲染路由对应的组件,并且在路由跳转时自动刷新页面。如果需要手动刷新页面,可以使用`<router-link>`组件或`router.push()`方法进行路由跳转。具体实现方法如下: 1. 在路由配置文件中,设置路由对应的组件。 ```javascript import { createRouter, createWebHistory } from 'vue-router' import Home from './views/Home.vue' import About from './views/About.vue' const routes = [ { path: '/', name: 'Home', component: Home }, { path: '/about', name: 'About', component: About } ] const router = createRouter({ history: createWebHistory(), routes }) export default router ``` 2. 在组件中使用`<router-link>`组件或`router.push()`方法进行路由跳转。 ```html <template> <div> <router-link to="/">Home</router-link> <router-link to="/about">About</router-link> <button @click="goHome">Go Home</button> <button @click="goAbout">Go About</button> </div> </template> <script> export default { methods: { goHome() { this.$router.push('/') }, goAbout() { this.$router.push('/about') } } } </script> ``` 3. 如果需要在路由跳转时手动刷新页面,可以在路由跳转前先跳转到一个空白页,然后在空白页的`beforeRouteEnter`钩子中再跳转回原来的页面,从而达到刷新页面的效果。 ```javascript // 在需要刷新页面的组件中 this.$router.push('/emptyPage') // 在空白页的组件中 <template> <div></div> </template> <script> export default { beforeRouteEnter(to, from, next) { next(vm => { vm.$router.replace(from.path) }) } } </script> ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值