在 github 的 vue-router 中找到同樣的一個(gè)問(wèn)題:3.0.1版本通過(guò)router實(shí)例無(wú)法跳轉(zhuǎn)
昨天發(fā)現(xiàn)有些路由不能正常跳轉(zhuǎn),找了一下發(fā)現(xiàn)都是那些實(shí)例化后使用 router.push 而不是直接使用 this.$router.push 的地方。
出現(xiàn)的情況是 router.push 后,url變化了,但是頁(yè)面沒(méi)有刷新,手動(dòng)刷新一下才出現(xiàn)應(yīng)有的畫(huà)面。
我看了一下 package.json,我的 vue 和 axios 是沒(méi)有寫(xiě)版本號(hào),但 vue-router 明明寫(xiě)了版本號(hào),怎么可能以前行的,現(xiàn)在就不行了呢?
然后,我使用 npm view vue-router 查看后才發(fā)現(xiàn)使用的已經(jīng)不是 package.json 中的版本了,于是斷定也許是我前幾天 npm update 了!
( 以后不要隨便 update 了! )
具體為什么新版本不行了,我也不太清楚。
最簡(jiǎn)單的解決辦法當(dāng)然是直接把 router.push 改成 this.$router.push
但是,如果這樣可以的話,我當(dāng)初為什么要在組件內(nèi)再實(shí)例化一個(gè) Router 呢?
顯然是因?yàn)橛行┑胤降?this 并不是 vue,那么,再實(shí)例化一個(gè) vue,然后使用 vue.$router 行嗎?
答案當(dāng)然是不行的,因?yàn)檫@個(gè) vue 與 其它地方的 vue 應(yīng)該又不是同一個(gè)對(duì)象了。
那么,終極的解決方案就是:
把全局的 vue 中的 router 加到 window 中,也就在 main.js 中使用:
window.router=router
然后其它任何地方就可以直接愉快地使用 router.push 等 router 的方法了。
分析原因:
實(shí)例后的 router 不能刷新頁(yè)面,應(yīng)該是因?yàn)樗c全局的vue中的 this.$router 的不是同一個(gè),而之前的版本中能直接這樣使用,應(yīng)該是使用了單例。
至于為什么不使用單例了,這個(gè)我怎么會(huì)知道?
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持錯(cuò)新站長(zhǎng)站。
新聞熱點(diǎn)
疑難解答
圖片精選