zoukankan      html  css  js  c++  java
  • vue路由使用踩坑点:当动态路由再使用路由name去匹配跳转时总是跳转到根路由的问题

      闲话少说,直接问题:

      之前我的路由时这么写的

    {
        path:'/serverInfo/:id',
        name:'serverInfo',
        component:() => import('@/views/serverRequest/SRInfo')
    }

      但是呢,头部做了个通知面板,代码如下:

            <el-popover
              popper-class="messagePopper"
              placement="bottom"
              width="300"
              v-model="visiblity"
              trigger="click">
              <div class="messageBox">
                <div class="title">通知</div>
                <div class="message" v-if="messageData.length === 0">暂无通知</div>
                <div v-else>
                <div class="message" v-for="item in messageData" @click="readMessage(item.id)">
                  <router-link :to="{
                    name:item.route,
                    params:{
                      messageId:item.rid
                    }
                  }">{{'【' + item.message + '】'}}</router-link>
                  <span>{{item.message_time}}</span>
                </div>
                </div>
              </div>
              <el-badge slot="reference" :value="messageData.length" class="item" :hidden="messageData.length === 0">
                <i class="messageStyle iconfont icon-tongzhi"></i>
                <span class="messageText">通知</span>
              </el-badge>
            </el-popover>

      看一下router-link部分通过name去跳转,并传递参数。

      然后我们可以看一下页面,order路由正常的,serverInfo就不正常了

      我们看下后台返回数据也是正常的有路由名字,这就很惆怅了。

      然后我们看下order的路由,order没有动态路由匹配。

    {
      path:'/order',
      name:'order',
      component:() => import('@/views/system/order')
    },

      所以初步猜测:是不是有动态路由匹配时,通过路由name去跳转,就会匹配不到全路径,而跑到根路由去呢?

      我们现在把serverInfo路由改一下:去掉动态路由匹配

    {
        path:'/serverInfo',
        name:'serverInfo',
        component:() => import('@/views/serverRequest/SRInfo')
    }

      改了之后,我们之前使用到的路由跳转的地方也得改下。我们需要传参数的地方就通过下面这种去传,也是一样的

    // <router-link :to="'/serverInfo/'+scope.row.srid"> 
    <router-link :to="{name:'serverInfo',params:{id:scope.row.srid}}">
      <span>{{scope.row.srid}}</span>
    </router-link>

      改成这样只会就发现一切正常了

      后来网友指出动态路由匹配的key不一致,检查发现的确如此,动态路由匹配写的 /:id ,而 name 匹配传参写的messageId,导致匹配不了路由,故出错。

  • 相关阅读:
    复习一allure
    本地push 到git hub 二
    项目过程中,测试总感觉自己的时间不够怎么办?
    记一次接口并发,酿成20万损失的惨案
    记录一次管理员组织应用的运行
    记录一次jmeter脚本开发缺少utf-8惹的祸
    记录一次pycharm中,引入其他类可用,下面总是有波浪线,而且Ctrl+b 无法查看类函数的源码
    Fiddler如何过滤无用的链接
    【bat】将当前文件夹及其子文件夹下的所有文件移动到新文件夹中
    python 安装python-docx模块(如何本地安装)
  • 原文地址:https://www.cnblogs.com/goloving/p/9206219.html
Copyright © 2011-2022 走看看