vue-router重写push方法,解决相同路径跳转报错问题


Posted in Javascript onAugust 07, 2020

修改vue-router的配置文件,默认位置router/index.js

import Vue from 'vue'
import Router from 'vue-router'
 
/**
 * 重写路由的push方法
 * 解决,相同路由跳转时,报错
 * 添加,相同路由跳转时,触发watch (针对el-menu,仅限string方式传参,形如"view?id=5")
 */
 
// 保存原来的push函数
const routerPush = Router.prototype.push 
// 重写push函数
Router.prototype.push = function push(location) {
 
 // 这个if语句在跳转相同路径的时候,在路径末尾添加新参数(一些随机数字)
 // 用来触发watch
 if(typeof(location)=="string"){
 var Separator = "&";
 if(location.indexOf('?')==-1) { Separator='?'; }
 location = location + Separator + "random=" + Math.random();
 }
 
 // 这个语句用来解决报错
 // 调用原来的push函数,并捕获异常
 return routerPush.call(this, location).catch(error => error)
}
 
Vue.use(Router)
export default new Router({
 routes: [
 {
  path: '/',
 
 }
 ]
})

补充知识:vue router-link 路径变化 页面内容不变

在VUE项目中有碰到过,vue 同一 路由页面 用router-link 或者 router.push() 访问同一路由页面,出现url地址有变化,但是页面内容没有变化,没有重新加载信息

解决方案如下

<router-link to="/home" @click.native="flushCom">首页</router-link>
<script>  
export default {
...
...
methods:{
 flushCom:function(){
 //router是路由实例,例如:var router = new Router({})
  //router.go(n)是路由的一个方法,意思是在history记录中前进或者后退多少步,0就表示还是当前,类似window.history.go(n)
 this.$router.go(0); 
 }
}
}
<script>

等于在router 链接 触发后 再通过click 时间 刷新本页面

以上这篇vue-router重写push方法,解决相同路径跳转报错问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery监听div内容的变化具体实现思路
Nov 04 Javascript
Javascript毫秒数用法实例
Feb 05 Javascript
基于RequireJS和JQuery的模块化编程日常问题解析
Apr 14 Javascript
Bootstrap标签页(Tab)插件使用方法
Mar 21 Javascript
vue+element实现批量删除功能的示例
Feb 28 Javascript
vue结合axios与后端进行ajax交互的方法
Jul 06 Javascript
jQuery中ajax请求后台返回json数据并渲染HTML的方法
Aug 08 jQuery
基于vue和react的spa进行按需加载的实现方法
Sep 29 Javascript
大转盘抽奖小程序版 转盘抽奖网页版
Apr 16 Javascript
在vue项目中引入vue-beauty操作方法
Feb 11 Javascript
Egg Vue SSR 服务端渲染数据请求与asyncData
Nov 24 Javascript
JS实现炫酷雪花飘落效果
Aug 19 Javascript
手把手带你搭建一个node cli的方法示例
Aug 07 #Javascript
Vue两种组件类型:递归组件和动态组件的用法
Aug 06 #Javascript
vue数据更新UI不刷新显示的解决办法
Aug 06 #Javascript
基于vue 动态菜单 刷新空白问题的解决
Aug 06 #Javascript
基于JavaScript的数据结构队列动画实现示例解析
Aug 06 #Javascript
解决vue动态下拉菜单 有数据未反应的问题
Aug 06 #Javascript
JavaScript中ES6规范中let和const的用法和区别
Aug 06 #Javascript
You might like
URL Rewrite的设置方法
2007/01/02 PHP
实用函数9
2007/11/08 PHP
php面向对象的方法重载两种版本比较
2008/09/08 PHP
PHP实现变色验证码实例
2014/01/06 PHP
Thinkphp自定义代码生成工具及用法说明(附下载地址)
2016/05/27 PHP
Windows2003下php5.4安装配置教程(IIS)
2016/06/30 PHP
使用PHPStorm+XDebug搭建单步调试环境
2017/11/19 PHP
jQuery使用手册之一
2007/03/24 Javascript
Javascript(AJAX)解析XML的代码(兼容FIREFOX/IE)
2010/07/11 Javascript
JavaScript实现QueryString获取GET参数的方法
2013/07/02 Javascript
文本有关的样式和jQuery求对象的高宽问题分别说明
2013/08/30 Javascript
关于jquery中全局函数each使用介绍
2013/12/10 Javascript
javascript中使用正则计算中文长度的例子
2014/04/29 Javascript
JQuery实现的图文自动轮播效果插件
2015/06/19 Javascript
JS实现鼠标框选效果完整实例
2016/06/20 Javascript
js实现按钮控制带有停顿效果的图片滚动
2016/08/30 Javascript
angularjs路由传值$routeParams详解
2020/09/05 Javascript
基于IView中on-change属性的使用详解
2018/03/15 Javascript
JS实现可针对算术表达式求值的计算器功能示例
2018/09/04 Javascript
vue观察模式浅析
2018/09/25 Javascript
bootstrap table.js动态填充单元格数据的多种方法
2019/07/18 Javascript
JS操作Fckeditor的一些常用方法(获取、插入等)
2020/02/19 Javascript
el-table树形表格表单验证(列表生成序号)
2020/05/31 Javascript
Vue路由的模块自动化与统一加载实现
2020/06/05 Javascript
mustache.js实现首页元件动态渲染的示例代码
2020/12/28 Javascript
Python中的exec、eval使用实例
2014/09/23 Python
Django中URLconf和include()的协同工作方法
2015/07/20 Python
python3 selenium 切换窗口的几种方法小结
2018/05/21 Python
python找出一个列表中相同元素的多个索引实例
2019/06/11 Python
关于Python Tkinter Button控件command传参问题的解决方式
2020/03/04 Python
Pycharm配置lua编译环境过程图解
2020/11/28 Python
详解使用HTML5的classList属性操作CSS类
2017/10/13 HTML / CSS
三只松鼠官方旗舰店:全网坚果销售第1
2017/11/25 全球购物
英国比较机场停车场网站:Airport Parking Essentials
2019/12/01 全球购物
2015年企业新年寄语
2014/12/08 职场文书
先进个人材料怎么写
2014/12/30 职场文书