Vue?Router如何刷新當前頁面
Vue項目, 在實際工作中, 有些時候需要在 加載完某些數(shù)據(jù)之后對當前頁面進行刷新, 以期 onMounted 等生命周期函數(shù), 或者 數(shù)據(jù)重新加載. 總之是期望頁面可以重新加載一次.
目前總結有三種途徑可實現(xiàn)以上需求:
一、reload 直接刷新頁面
window.location.reload(); $router.go(0);
相當于按了 F5, 因此缺點也很明顯, 體驗感不佳, 因為要加載所有頁面資源相對較慢, 比較耗時.
二、Vue Router 刷新當前頁面
這個時候, 我們通過 $router.push 一個 refresh 路由的形式實現(xiàn), 具體步驟如下:
步驟一:
新建一個 vue 文件, 文件中代碼如下 ( 僅需要如下代碼即可 ) :
<template>
<div></div>
</template>
<script >
export default {
beforeRouteEnter(to, from, next) {
next(vm => {
vm.$router.replace(from.fullPath);
});
},
setup() {}
}
</script>
步驟二:
在你的路由文件中, 配置上述文件路由, 示例代碼:
routes 數(shù)組中直接添加就行
{
path: '/refresh',
name: 'refresh',
component: () => import('步驟一中創(chuàng)建文件的路徑')
},
步驟三:
在目標位置, 使用 $router.push 上述路由即可, 示例代碼:
$router.push({
name: 'refresh',
});
以上三步, 結束!
三、依賴注入方式實現(xiàn) (即, provide/inject )
中心思想: 通過 v-if 來切換 router-view 的 顯示/隱藏 從而實現(xiàn)重新加載組件的目的. 步驟如下.
步驟一:
修改 路由出口文件 ( 我測試時是在 App.vue 文件中加的 <router-view /> ), 通過 provide 提供一個刷新方法給后代組件.
注意: 我的Demo中沒有測試路由嵌套的場景, 如果你是路由嵌套, 只想刷新嵌套的子路由, 那在這一步修改的就應該是 子路由 出口文件.
核心代碼如下:
<template>
<div id="app">
<!-- <router-view></router-view> -->
<router-view v-if="isRefreshFlag"></router-view>
</div>
</template>
<script setup>
import { ref, nextTick, provide } from "vue";
const isRefreshFlag = ref(true)
function reloadPage() {
isRefreshFlag.value = false
nextTick(() => {
isRefreshFlag.value = true
})
}
provide("reloadPage", reloadPage)
</script>
<style>
</style>
步驟二:
在目標組件的目標位置, 通過 inject 調(diào)用步驟一中的 reloadPage() 方法. 示例代碼:
<template>
<div>
...
<button @click="refreshPage">刷新頁面</button>
</div>
</template>
<script setup>
import { inject } from "vue";
const reloadPage = inject("reloadPage");
function refreshPage() {
reloadPage();
}
</script>
<style>
</style>以上兩步, 結束!
以上三種方式, 親測有效, 不過是 Vue 3 的代碼風格, Vue 2 請自行轉換.
到此這篇關于Vue Router如何刷新當前頁面的文章就介紹到這了,更多相關Vue Router刷新頁面內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue3中內(nèi)置組件Teleport的基本使用與典型案例
Teleport是一種能夠?qū)⑽覀兊哪0逡苿拥紻OM中Vue app之外的其他位置的技術,下面這篇文章主要給大家介紹了關于Vue3中內(nèi)置組件Teleport的基本使用與典型案例的相關資料,需要的朋友可以參考下2023-04-04
報錯[vuex] unknown action type: userLogin問
這篇文章主要介紹了報錯[vuex] unknown action type: userLogin問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
vue+element table表格實現(xiàn)動態(tài)列篩選的示例代碼
這篇文章主要介紹了vue+element table表格實現(xiàn)動態(tài)列篩選的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01
簡單了解Vue computed屬性及watch區(qū)別
這篇文章主要介紹了通過實例解析Vue computed屬性及watch區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07

