iView-admin 动态路由问题的解决方法
IView-admin在使用的时候
跳转客户详细后,点击其它页面,然后再从选项卡进入页面时,发下控制台报错,不能正常打开客户详细页面
[vue-router]Routewithname'customer/detail/:id'doesnotexist
地址栏的地址变为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})来跳转
在浏览器的LocalStorage里发现是这样存储的
{"name":"customer/detail","path":"/customer/detail/150","meta":{"title":"客户详细","hideInMenu":true}}
name上边没有客户详细的ID信息,所以跳转的时候出现了问题。
现将mian.vuetruenToPage下新增代码,采用this.$router.push({path:path})方式来跳转
turnToPagePath(path){
if(name.indexOf('isTurnByHref_')>-1){
window.open(name.split('_')[1])
return
}
this.$router.push({
path:path
})
},
然后修改main.vuehandleClick部分代码
handleClick(item){
//this.turnToPage(item.name)
this.turnToPagePath(item.path)
}
问题解决
由此引发了新问题
从列表打开id为150的客户信息,再从列表打开id为140的客户信息。从别的页面点选项卡跳转到客户详细页面发现还是进入到150的客户信息,而不是最新140的客户信息
解决方法,修改util.js
之前的代码
exportconstgetNewTagList=(list,newRoute)=>{
const{name,path,meta}=newRoute
letnewList=[...list]
if(newList.findIndex(item=>item.name===name)>=0)returnnewList
elsenewList.push({name,path,meta})
returnnewList
}
修改后的代码
exportconstgetNewTagList=(list,newRoute)=>{
const{name,path,meta}=newRoute
letnewList=[...list]
let_index=newList.findIndex(item=>item.name===name)
if(_index>=0){
if(newList[_index].path!==path){//如果name已经存在,判断path值
newList[_index].path=path//如果不一样,修改path值
}
returnnewList
}elsenewList.push({name,path,meta})
returnnewList
}
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。