iView-admin 动态路由问题的解决方法


Posted in Javascript onOctober 03, 2018

 IView-admin 在使用的时候

跳转客户详细后,点击其它页面,然后再从选项卡进入页面时,发下控制台 报错,不能正常打开客户详细页面

[vue-router] Route with name 'customer/detail/:id' does not exist

地址栏的地址变为 http://localhost:8080/  正确的地址为 http://localhost:8080/customer/detail/150

路由器配置如下

{

  path: 'detail/:id',

  name: 'customer/detail',

  meta: {

   title: '客户详细',

   hideInMenu: true

  },

  component: () => import('@/view/customer/detail/detail.vue')

}

最后找到原因是,IView-admin 路由跳转使用的是

turnToPage (name) {

 if (name.indexOf('isTurnByHref_') > -1) {

  window.open(name.split('_')[1])

  return

 }

 this.$router.push({

  name: name

 })
},

采用 this.$router.push({name: name}) 来跳转

在浏览器的Local Storage里发现是这样存储的

{"name":"customer/detail","path":"/customer/detail/150","meta":{"title":"客户详细","hideInMenu":true}}

name 上边没有客户详细的ID信息,所以跳转的时候出现了问题。

现将 mian.vue truenToPage 下新增代码,采用this.$router.push({path: path})方式来跳转

turnToPagePath (path) {

 if (name.indexOf('isTurnByHref_') > -1) {

  window.open(name.split('_')[1])

  return

 }

 this.$router.push({

  path: path

 })
},

然后修改 main.vue handleClick 部分代码

handleClick (item) {

 // this.turnToPage(item.name)

 this.turnToPagePath(item.path)

}

问题解决

由此引发了新问题

从列表打开id为150的客户信息,再从列表打开id为140的客户信息。从别的页面点选项卡跳转到客户详细页面 发现还是进入到 150的客户信息,而不是最新 140的客户信息

解决方法,修改 util.js 

之前的代码

export const getNewTagList = (list, newRoute) => {

 const { name, path, meta } = newRoute

 let newList = [...list]

 if (newList.findIndex(item => item.name === name) >= 0) return newList

 else newList.push({ name, path, meta })

 return newList

}

修改后的代码 

export const getNewTagList = (list, newRoute) => {

 const { name, path, meta } = newRoute

 let newList = [...list]

 let _index = newList.findIndex(item => item.name === name)

 if (_index >= 0) {

  if (newList[_index].path !== path) {  // 如果name已经存在,判断path值

   newList[_index].path = path      // 如果不一样,修改path值

  }

  return newList

 } else newList.push({ name, path, meta })

 return newList

}

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
零基础学JavaScript最新动画教程+iso光盘下载
Jan 22 Javascript
用JavaScript实现动画效果的方法
Jul 20 Javascript
jquery $.each() 使用小探
Aug 23 Javascript
js使用栈来实现10进制转8进制与取除数及余数
Jun 11 Javascript
JS实现鼠标箭头变成一个燃烧烛光效果的方法
Feb 28 Javascript
超详细的javascript数组方法汇总
Nov 21 Javascript
webpack中引用jquery的简单实现
Jun 08 Javascript
JS实现重新加载当前页面或者父页面的几种方法
Nov 30 Javascript
详解JavaScript的闭包、IIFE、apply、函数与对象
Dec 21 Javascript
从零开始学习Node.js系列教程六:EventEmitter发送和接收事件的方法示例
Apr 13 Javascript
vue组件入门知识全梳理
Sep 21 Javascript
ant design的table组件实现全选功能以及自定义分页
Nov 17 Javascript
Angular resolve基础用法详解
Oct 03 #Javascript
解决angularjs service中依赖注入$scope报错的问题
Oct 02 #Javascript
angular.js实现列表orderby排序的方法
Oct 02 #Javascript
Angularjs实现数组随机排序的方法
Oct 02 #Javascript
解决angular双向绑定无效果,ng-model不能正常显示的问题
Oct 02 #Javascript
angularjs获取到My97DatePicker选中的值方法
Oct 02 #Javascript
angular ng-model 无法获取值的处理方法
Oct 02 #Javascript
You might like
php echo()和print()、require()和include()函数区别说明
2010/03/27 PHP
比较详细PHP生成静态页面教程
2012/01/10 PHP
自己写的php curl库实现整站克隆功能
2015/02/12 PHP
Display SQL Server Login Mode
2007/06/21 Javascript
js每次Title显示不同的名言
2008/09/25 Javascript
对new functionName()定义一个函数的理解
2014/05/22 Javascript
js实现完全自定义可带多级目录的网页鼠标右键菜单方法
2015/02/28 Javascript
Bootstrap媒体对象学习使用
2017/03/07 Javascript
详解AngularJS 路由 resolve用法
2017/04/24 Javascript
JS 设置Cookie 有效期 检测cookie
2017/06/15 Javascript
vue.js内部自定义指令与全局自定义指令的实现详解(利用directive)
2017/07/11 Javascript
js阻止默认右键的下拉菜单方法
2018/01/02 Javascript
element ui 表格动态列显示空白bug 修复方法
2018/09/04 Javascript
node中IO以及定时器优先级详解
2019/05/10 Javascript
Vue2.x通用条件搜索组件的封装及应用详解
2019/05/28 Javascript
解决layui数据表格Date日期格式的回显Object的问题
2019/09/19 Javascript
Vue项目中Api的组织和返回数据处理的操作
2019/11/04 Javascript
微信小程序 scroll-view的使用案例代码详解
2020/06/11 Javascript
Vue实现省市区三级联动
2020/12/27 Vue.js
[53:43]VP vs NewBee Supermajor 胜者组 BO3 第三场 6.5
2018/06/06 DOTA
python实现简单的TCP代理服务器
2014/10/08 Python
关于你不想知道的所有Python3 unicode特性
2014/11/28 Python
python根据给定文件返回文件名和扩展名的方法
2015/03/27 Python
Python远程桌面协议RDPY安装使用介绍
2015/04/15 Python
Python实现的归并排序算法示例
2017/11/21 Python
Python修改文件往指定行插入内容的实例
2019/01/30 Python
Python Matplotlib实现三维数据的散点图绘制
2019/03/19 Python
CSS3实战第一波 让我们尽情的圆角吧
2010/08/27 HTML / CSS
HTML5是什么 HTML5是什么意思 HTML5简介
2012/10/26 HTML / CSS
《郑和远航》教学反思
2014/04/16 职场文书
意外伤害赔偿协议书范本
2014/09/28 职场文书
幼儿园辞职信范文
2015/02/27 职场文书
2015年暑假工作总结
2015/07/13 职场文书
react如何快速设置文件路径别名
2021/04/28 Javascript
Django基础CBV装饰器和中间件
2022/03/22 Python
i5-10400f处理相当于i7多少水平
2022/04/19 数码科技