国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue-router3.0版本中 router.push 不能刷新頁面的問題

2019-11-19 13:53:00
字體:
來源:轉載
供稿:網友

在 github 的 vue-router 中找到同樣的一個問題:3.0.1版本通過router實例無法跳轉

昨天發現有些路由不能正常跳轉,找了一下發現都是那些實例化后使用 router.push 而不是直接使用 this.$router.push 的地方。
出現的情況是 router.push 后,url變化了,但是頁面沒有刷新,手動刷新一下才出現應有的畫面。

我看了一下 package.json,我的 vue 和 axios 是沒有寫版本號,但 vue-router 明明寫了版本號,怎么可能以前行的,現在就不行了呢?

然后,我使用 npm view vue-router 查看后才發現使用的已經不是 package.json 中的版本了,于是斷定也許是我前幾天 npm update 了!

( 以后不要隨便 update 了! )

具體為什么新版本不行了,我也不太清楚。

最簡單的解決辦法當然是直接把 router.push 改成 this.$router.push

但是,如果這樣可以的話,我當初為什么要在組件內再實例化一個 Router 呢?

顯然是因為有些地方的 this 并不是 vue,那么,再實例化一個 vue,然后使用 vue.$router 行嗎?

答案當然是不行的,因為這個 vue 與 其它地方的 vue 應該又不是同一個對象了。

那么,終極的解決方案就是:

把全局的 vue 中的 router 加到 window 中,也就在 main.js 中使用:

window.router=router

然后其它任何地方就可以直接愉快地使用 router.push 等 router 的方法了。

分析原因:

實例后的 router 不能刷新頁面,應該是因為它與全局的vue中的 this.$router 的不是同一個,而之前的版本中能直接這樣使用,應該是使用了單例。

至于為什么不使用單例了,這個我怎么會知道?

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 威海市| 施秉县| 璧山县| 玉树县| 白城市| 米易县| 青阳县| 浦江县| 宜川县| 观塘区| 沅江市| 会宁县| 邵东县| 疏附县| 勃利县| 绥芬河市| 新闻| 东乌珠穆沁旗| 昭平县| 阳曲县| 乌审旗| 逊克县| 嘉义市| 通山县| 虎林市| 裕民县| 济阳县| 沾益县| 响水县| 上思县| 大同市| 沈阳市| 岱山县| 淮北市| 巨野县| 顺昌县| 横山县| 剑阁县| 泰州市| 即墨市| 宝兴县|