vue項(xiàng)目刷新當(dāng)前頁面的三種方式(重載當(dāng)前頁面數(shù)據(jù))
vue項(xiàng)目刷新當(dāng)前頁面的三種方式(重載當(dāng)前頁面數(shù)據(jù))
一、this.$router.go(0)
相當(dāng)于F5刷新,這種方法雖然代碼很少,只有一行,但是體驗(yàn)很差。頁面會(huì)一瞬間的白屏,體驗(yàn)不是很好
二、location.reload()
這種也是一樣,畫面一閃,體驗(yàn)不是很好,相當(dāng)于頁面刷新
推薦解決方法:
三、用provide / inject 組合
原理:允許一個(gè)祖先組件向其所有子孫后代注入一個(gè)依賴,不論組件層次有多深,并在起上下游關(guān)系成立的時(shí)間里始終生效
在App.vue,聲明reload方法,控制router-view的顯示或隱藏,從而控制頁面的再次加載。
<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>
在需要用到刷新的頁面。在頁面注入App.vue組件提供(provide)的 reload 依賴,在邏輯完成之后(刪除或添加…),直接this.reload()調(diào)用,即可刷新當(dāng)前頁面。
注入reload方法
export default { inject: ['reload'], }
在需要重載的地方直接調(diào)用
this.reload()
PS:vue項(xiàng)目刷新當(dāng)前頁面的三種方法
1、最直接整個(gè)頁面重新刷新。
location. reload(); this.$router.go(0); // 這兩種都可以刷新當(dāng)前頁面的,缺點(diǎn)就是相當(dāng)于按ctrl+F5 強(qiáng)制刷新那種,整個(gè)頁面重新加載,會(huì)出現(xiàn)一個(gè)瞬間的空白頁面,體驗(yàn)不好。
2、新建一個(gè)空白頁面,點(diǎn)擊確定的時(shí)候先跳轉(zhuǎn)到這個(gè)空白頁,然后再立馬跳轉(zhuǎn)回來。這個(gè)方式,相比第一種不會(huì)出現(xiàn)一瞬間的空白頁,只是地址欄有個(gè)快速的切換的過程,也可采用。
3、provide / inject 刷新相對(duì)比較理想。
//首先在app.vue進(jìn)行修改 <template> <div id="app"> // 控制router-view的顯示或隱藏,從而控制頁面的再次加載 <router-view v-if="isRouterAlive"/> </div> </template> <script> export default { name: "App", provide() { return { reload : this.reload, } }, data() { return { isRouterAlive:true, }; }, created(){}, methods: { // 通過聲明reload方法,控制router-view的顯示或隱藏,從而控制頁面的再次加載 reload(){ this.isRouterAlive = false; this.$nextTick(() => { this.isRouterAlive = true; }) }, }, }; </script>
在需要刷新的頁面引入后直接調(diào)用即可
<template> <div> <el-button icon="el-icon-refresh" @click="refresh">點(diǎn)擊刷新</el-button> </div> </template> <script> export default { //引用vue reload方法 inject: ['reload'], name:"", data() { return { } }, methods: { refresh () { this.reload() } } } </script>
這樣就實(shí)現(xiàn)了子組件調(diào)取reload方法就實(shí)現(xiàn)了刷新vue組件的功能,而且實(shí)現(xiàn)了組件跨越層級(jí)傳遞數(shù)據(jù)方法。
到此這篇關(guān)于vue項(xiàng)目刷新當(dāng)前頁面的三種方式(重載當(dāng)前頁面數(shù)據(jù))的文章就介紹到這了,更多相關(guān)vue刷新當(dāng)前頁面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue組件數(shù)據(jù)傳遞與props校驗(yàn)方式
這篇文章主要介紹了Vue組件數(shù)據(jù)傳遞與props校驗(yàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Vue?CompositionAPI中watch和watchEffect的區(qū)別詳解
這篇文章主要為大家詳細(xì)介紹了Vue?CompositionAPI中watch和watchEffect的區(qū)別,文中的示例代碼簡潔易懂,希望對(duì)大家學(xué)習(xí)Vue有一定的幫助2023-06-06vue中使用vue-print.js實(shí)現(xiàn)多頁打印
這篇文章主要介紹了vue中使用vue-print.js實(shí)現(xiàn)多頁打印,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03vue3中reactive和ref的實(shí)現(xiàn)與區(qū)別詳解
reactive和ref都是vue3實(shí)現(xiàn)響應(yīng)式系統(tǒng)的api,他們是如何實(shí)現(xiàn)響應(yīng)式的呢,reactive和ref又有什么區(qū)別呢,下面小編就來和大家詳細(xì)講講,希望對(duì)大家有所幫助2023-10-10vue中的data,computed,methods,created,mounted用法及說明
這篇文章主要介紹了vue中的data,computed,methods,created,mounted用法及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07