Vue 刷新当前页面,并重新加载页面数据

在Vue应用中,当需要在增删改操作后刷新页面并重载数据时,可以避免使用`this.$router.go(0)`导致的空白页体验问题。通过`provide / inject`这对选项,实现路由视图的隐藏与显示来触发重渲染。具体做法是在根组件`APP.vue`中设置`v-if="isRouterAlive"`的`router-view`,并在子组件中注入并调用刷新方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

业务场景:在管理后台,在执行完,增,删,改,操作的时候。我们需要刷新一下页面,重载数据。在JQ中我们会用到location.reload()方法,刷新页面;在vue中,这里需要用到一个 provide / inject 这对用例。(其他方法:this.$router.go(0),会强制刷新,出现空白页面体验不好)

这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在起上下游关系成立的时间里始终生效。

实现原理就是通过控制router-view 的显示与隐藏,来重渲染路由区域,重而达到页面刷新的效果,show -> flase -> show

具体代码如下:

1.首先在我们的根组件APP.vue里面,写入刷新方法,路由初始状态是显示的

<template>
  <div id="app">
    <keep-alive>
    <router-view  v-show="$route.meta.keepAlive"/>
    </keep-alive>
<router-view v-if="isRouterAlive"/> <Tabbar v-show="$route.meta.showFooter"></Tabbar> </div> </template> <script> // 样式重置 common.css import "./assets/common.css" import SHeader from './components_c/SearchHeader.vue' import Tabbar from './components_c/Tabbar' export default { name: 'App', provide(){ return{ reload:this.reload } }, data(){ return{ isRouterAlive:true } }, components:{ SHeader, Tabbar }, methods: { reload (){ this.isRouterAlive = false this.$nextTick(function(){ this.isRouterAlive = true }) } } } </script> <style lang="scss" scoped> </style>

<router-view v-if="isRouterAlive"></router-view>  在isRouterAlive 为true的地方 使用刷新 ,然后在其他组件或者页面中调用相应方法就行

2、然后在子组件中引用

 

3、执行完相应操作之后,调用reload方法

 

转载于:https://www.cnblogs.com/mica/p/10642194.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值