• 【已解决】 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
    }
    

      

  • 相关阅读:
    QTP实践总结
    webStorm快捷键大全
    linux下vi命令大全
    Oracle中查询各种对象的方法小结
    c#取出LDAP SearchResult所有属性
    Cool Edit Pro 2.0详细教程(转)
    移动端 触摸事件 ontouchstart、ontouchmove、ontouchend、ontouchcancel
    跨平台运行ASP.NET Core 1.0(转载)
    Linux下使用NMON监控、分析系统性能
    EAIntroView–高度可定制的iOS应用欢迎页通用解决方案
  • 原文地址:https://www.cnblogs.com/yanzhen/p/9518894.html
Copyright © 2020-2023  润新知