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,导致匹配不了路由,故出错。

  • 相关阅读:
    空间距离计算
    一种支持多种并行环境的栅格地理计算并行算子
    发布或重启线上服务时抖动问题解决方案
    jetty9优化的两处地方
    mysql空间扩展 VS PostGIS
    多流向算法GPU并行化
    GDAL并行I/O
    深入浅出空间索引:2
    深入浅出空间索引:为什么需要空间索引
    virtualBox中的centOS虚拟机硬盘扩容
  • 原文地址:https://www.cnblogs.com/goloving/p/9206219.html
Copyright © 2011-2022 走看看