vue項(xiàng)目中路由跳轉(zhuǎn)頁(yè)面不變問(wèn)題及解決
vue中路由跳轉(zhuǎn)頁(yè)面不變
問(wèn)題
今天在開(kāi)發(fā)vue移動(dòng)端項(xiàng)目的過(guò)程中發(fā)現(xiàn)了一個(gè)bug,就是當(dāng)按返回鍵的時(shí)候頁(yè)面并沒(méi)有發(fā)生變化,一開(kāi)始還以為是沒(méi)有監(jiān)聽(tīng)到返回事件,但是通過(guò)測(cè)試之后發(fā)現(xiàn)返回事件監(jiān)聽(tīng)成功了,路由也發(fā)生了變化,相應(yīng)事件也觸發(fā)了,就是頁(yè)面視圖沒(méi)有跟著改變。
解決方法
項(xiàng)目中路由設(shè)置的是 hash模式,所以對(duì) hashchange 事件進(jìn)行監(jiān)聽(tīng)(hash模式下,路由的變化會(huì)觸發(fā)hashchange事件)
在App.vue中給hashchange綁定事件:
?mounted() { ? ? // 檢測(cè)瀏覽器路由改變頁(yè)面不刷新問(wèn)題,hash模式的工作原理是 hashchange事件 ? ? window.addEventListener('hashchange', () => { ? ? let currentPath = window.location.hash.slice(1) ? ? if (this.$route.path !== currentPath) { ? ? ? this.$router.push(currentPath) ? ? } ? }, false) }
路由跳轉(zhuǎn)頁(yè)面不刷新、this.$router.go(-1)不生效
vue項(xiàng)目中遇見(jiàn)了這樣一個(gè)問(wèn)題:使用this.$router.go(-1)回到上一頁(yè),路由改變了,但是頁(yè)面展示還是停留在當(dāng)前頁(yè)面,需要手動(dòng)刷新才能渲染跳轉(zhuǎn)后的頁(yè)面。
router-view 如下:
<router-view :key="$route.fullPath"></router-view>
一般情況用到上面這種寫(xiě)法就能解決問(wèn)題了,但是我這里還是不生效。
然后我就想到了如下方法:
解決思路
在beforeRouteEnter鉤子時(shí),使用sessionStorage存儲(chǔ)from.path;然后在點(diǎn)擊返回的時(shí)候使用this.$router.push
代碼:
beforeRouteEnter(to, from, next) { ? ? next(()=> { ? ? ? window.sessionStorage.setItem('lasterRouter', from.path) ? ? }) ? },
//返回上一頁(yè) this.$router.push(window.sessionStorage.getItem('lasterRouter'))
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue框架制作購(gòu)物車(chē)小球動(dòng)畫(huà)效果實(shí)例代碼
最近在學(xué)習(xí)前端制作了一個(gè)購(gòu)物車(chē)小球的動(dòng)畫(huà)效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-09-09如何在vuejs項(xiàng)目中使用md5加密密碼的實(shí)現(xiàn)
本文主要介紹了如何在vuejs項(xiàng)目中使用md5加密密碼的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08vue Cli 環(huán)境刪除與重裝教程 - 版本文檔
這篇文章主要介紹了vue Cli 環(huán)境刪除與重裝教程 - 版本文檔,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法(總結(jié)篇)
這篇文章主要介紹了解決webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法,需要的朋友可以參考下2018-01-01VUE實(shí)現(xiàn)一個(gè)Flappy Bird游戲的示例代碼
這篇文章主要介紹了VUE實(shí)現(xiàn)一個(gè)Flappy Bird的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04vue?element-ui的el-input-number默認(rèn)值設(shè)置為空方法
這篇文章主要給大家介紹了關(guān)于vue?element-ui的el-input-number默認(rèn)值設(shè)置為空的相關(guān)資料,el-input-number組件是Element?UI非常常用的一個(gè)數(shù)字輸入框組件,它提供了默認(rèn)值設(shè)置的選項(xiàng),需要的朋友可以參考下2023-08-08解決antd 表單設(shè)置默認(rèn)值initialValue后驗(yàn)證失效的問(wèn)題
這篇文章主要介紹了解決antd 表單設(shè)置默認(rèn)值initialValue后驗(yàn)證失效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11