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

 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

}

以上是 iView-admin 动态路由问题的解决方法 的全部内容, 来源链接: utcz.com/z/313010.html

回到顶部