您好,登錄后才能下訂單哦!
修改vue-router的配置文件,默認(rèn)位置router/index.js
import Vue from 'vue' import Router from 'vue-router' /** * 重寫路由的push方法 * 解決,相同路由跳轉(zhuǎn)時(shí),報(bào)錯(cuò) * 添加,相同路由跳轉(zhuǎn)時(shí),觸發(fā)watch (針對(duì)el-menu,僅限string方式傳參,形如"view?id=5") */ // 保存原來(lái)的push函數(shù) const routerPush = Router.prototype.push // 重寫push函數(shù) Router.prototype.push = function push(location) { // 這個(gè)if語(yǔ)句在跳轉(zhuǎn)相同路徑的時(shí)候,在路徑末尾添加新參數(shù)(一些隨機(jī)數(shù)字) // 用來(lái)觸發(fā)watch if(typeof(location)=="string"){ var Separator = "&"; if(location.indexOf('?')==-1) { Separator='?'; } location = location + Separator + "random=" + Math.random(); } // 這個(gè)語(yǔ)句用來(lái)解決報(bào)錯(cuò) // 調(diào)用原來(lái)的push函數(shù),并捕獲異常 return routerPush.call(this, location).catch(error => error) } Vue.use(Router) export default new Router({ routes: [ { path: '/', } ] })
補(bǔ)充知識(shí):vue router-link 路徑變化 頁(yè)面內(nèi)容不變
在VUE項(xiàng)目中有碰到過(guò),vue 同一 路由頁(yè)面 用router-link 或者 router.push() 訪問(wèn)同一路由頁(yè)面,出現(xiàn)url地址有變化,但是頁(yè)面內(nèi)容沒(méi)有變化,沒(méi)有重新加載信息
解決方案如下
<router-link to="/home" @click.native="flushCom">首頁(yè)</router-link> <script> export default { ... ... methods:{ flushCom:function(){ //router是路由實(shí)例,例如:var router = new Router({}) //router.go(n)是路由的一個(gè)方法,意思是在history記錄中前進(jìn)或者后退多少步,0就表示還是當(dāng)前,類似window.history.go(n) this.$router.go(0); } } } <script>
等于在router 鏈接 觸發(fā)后 再通過(guò)click 時(shí)間 刷新本頁(yè)面
以上這篇vue-router重寫push方法,解決相同路徑跳轉(zhuǎn)報(bào)錯(cuò)問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。