vue-router重寫push方法,解決相同路徑跳轉(zhuǎn)報(bào)錯(cuò)問題
修改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")
*/
// 保存原來的push函數(shù)
const routerPush = Router.prototype.push
// 重寫push函數(shù)
Router.prototype.push = function push(location) {
// 這個(gè)if語句在跳轉(zhuǎn)相同路徑的時(shí)候,在路徑末尾添加新參數(shù)(一些隨機(jī)數(shù)字)
// 用來觸發(fā)watch
if(typeof(location)=="string"){
var Separator = "&";
if(location.indexOf('?')==-1) { Separator='?'; }
location = location + Separator + "random=" + Math.random();
}
// 這個(gè)語句用來解決報(bào)錯(cuò)
// 調(diào)用原來的push函數(shù),并捕獲異常
return routerPush.call(this, location).catch(error => error)
}
Vue.use(Router)
export default new Router({
routes: [
{
path: '/',
}
]
})
補(bǔ)充知識(shí):vue router-link 路徑變化 頁面內(nèi)容不變
在VUE項(xiàng)目中有碰到過,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是路由實(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ā)后 再通過click 時(shí)間 刷新本頁面
以上這篇vue-router重寫push方法,解決相同路徑跳轉(zhuǎn)報(bào)錯(cuò)問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- vue-router使用next()跳轉(zhuǎn)到指定路徑時(shí)會(huì)無限循環(huán)問題
- vue中@路徑無法跳轉(zhuǎn)到指定文件的解決
- Nginx配置Vue項(xiàng)目,無法按路徑跳轉(zhuǎn)及刷新404的解決方案
- vue-router解決相同路徑跳轉(zhuǎn)報(bào)錯(cuò)的問題
- 解決vue項(xiàng)目路徑不正確,自動(dòng)跳轉(zhuǎn)404的問題
- vue-router嵌套路由方式(頁面路徑跳轉(zhuǎn)但頁面顯示空白)
- vue路由相對(duì)路徑跳轉(zhuǎn)方式
- vue頁面不能根據(jù)路徑進(jìn)行跳轉(zhuǎn)的解決方法
相關(guān)文章
vue中用js如何實(shí)現(xiàn)循環(huán)可編輯表格
這篇文章主要介紹了vue中用js如何實(shí)現(xiàn)循環(huán)可編輯表格,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
vue項(xiàng)目中echarts自適應(yīng)問題的高級(jí)解決過程
雖然老早就看過很多echarts的例子,但自己接觸的項(xiàng)目中一直都沒有真正用到過,直到最近才開始真正使用,下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中echarts自適應(yīng)問題的高級(jí)解決過程,需要的朋友可以參考下2023-05-05
移動(dòng)端滑動(dòng)切換組件封裝 vue-swiper-router實(shí)例詳解
這篇文章主要介紹了移動(dòng)端滑動(dòng)切換組件封裝 vue-swiper-router實(shí)例詳解,需要的朋友可以參考下2018-11-11
VUE 配置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-09
webpack+vue+express(hot)熱啟動(dòng)調(diào)試簡(jiǎn)單配置方法
今天小編就為大家分享一篇webpack+vue + express (hot) 熱啟動(dòng)調(diào)試簡(jiǎn)單配置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09

