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 }
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。