溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vue-router重寫push方法,解決相同路徑跳轉(zhuǎn)報(bào)錯(cuò)問(wèn)題

發(fā)布時(shí)間:2020-09-23 12:07:21 來(lái)源:腳本之家 閱讀:1142 作者:jkdgvse 欄目:開發(fā)技術(shù)

修改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è)參考,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI