vue-router重寫push方法,解決相同路徑跳轉(zhuǎn)報錯問題
修改vue-router的配置文件,默認(rèn)位置router/index.js
import Vue from 'vue' import Router from 'vue-router' /** * 重寫路由的push方法 * 解決,相同路由跳轉(zhuǎn)時,報錯 * 添加,相同路由跳轉(zhuǎn)時,觸發(fā)watch (針對el-menu,僅限string方式傳參,形如"view?id=5") */ // 保存原來的push函數(shù) const routerPush = Router.prototype.push // 重寫push函數(shù) Router.prototype.push = function push(location) { // 這個if語句在跳轉(zhuǎn)相同路徑的時候,在路徑末尾添加新參數(shù)(一些隨機(jī)數(shù)字) // 用來觸發(fā)watch if(typeof(location)=="string"){ var Separator = "&"; if(location.indexOf('?')==-1) { Separator='?'; } location = location + Separator + "random=" + Math.random(); } // 這個語句用來解決報錯 // 調(diào)用原來的push函數(shù),并捕獲異常 return routerPush.call(this, location).catch(error => error) } Vue.use(Router) export default new Router({ routes: [ { path: '/', } ] })
補(bǔ)充知識:vue router-link 路徑變化 頁面內(nèi)容不變
在VUE項目中有碰到過,vue 同一 路由頁面 用router-link 或者 router.push() 訪問同一路由頁面,出現(xiàn)url地址有變化,但是頁面內(nèi)容沒有變化,沒有重新加載信息
解決方案如下
<router-link to="/home" @click.native="flushCom">首頁</router-link> <script> export default { ... ... methods:{ flushCom:function(){ //router是路由實例,例如:var router = new Router({}) //router.go(n)是路由的一個方法,意思是在history記錄中前進(jìn)或者后退多少步,0就表示還是當(dāng)前,類似window.history.go(n) this.$router.go(0); } } } <script>
等于在router 鏈接 觸發(fā)后 再通過click 時間 刷新本頁面
以上這篇vue-router重寫push方法,解決相同路徑跳轉(zhuǎn)報錯問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中用js如何實現(xiàn)循環(huán)可編輯表格
這篇文章主要介紹了vue中用js如何實現(xiàn)循環(huán)可編輯表格,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09vue項目中echarts自適應(yīng)問題的高級解決過程
雖然老早就看過很多echarts的例子,但自己接觸的項目中一直都沒有真正用到過,直到最近才開始真正使用,下面這篇文章主要給大家介紹了關(guān)于vue項目中echarts自適應(yīng)問題的高級解決過程,需要的朋友可以參考下2023-05-05移動端滑動切換組件封裝 vue-swiper-router實例詳解
這篇文章主要介紹了移動端滑動切換組件封裝 vue-swiper-router實例詳解,需要的朋友可以參考下2018-11-11VUE 配置vue-devtools調(diào)試工具及安裝方法
vue-devtools是一款基于chrome瀏覽器的插件,用于vue應(yīng)用的調(diào)試,這款vue調(diào)試神器可以極大地提高我們的調(diào)試效率。幫助我們快速的調(diào)試開發(fā)vue應(yīng)用。這篇文章主要介紹了VUE 配置vue-devtools調(diào)試工具及安裝步驟 ,需要的朋友可以參考下2018-09-09webpack+vue+express(hot)熱啟動調(diào)試簡單配置方法
今天小編就為大家分享一篇webpack+vue + express (hot) 熱啟動調(diào)試簡單配置方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09