美文网首页react & vue & angular
vue - 路由带参跳转

vue - 路由带参跳转

作者: 梁庄十年 | 来源:发表于2022-06-22 00:19 被阅读0次

vue路由传参按照传参方式可划分为params传参和query传参; params传参分为在url中显示和影藏参数两种方式

1 params传参(url地址栏显示参数)

1.1 声明式 router-link

通过router-link的to属性实现,该方法的参数可以是一个字符串;使用该方式时,需要子路由中提前配置好参数,如:

// 1 路由配置
   {
     path: 'content/:id',
     name: 'Content',
     component: Content,
   },
// 2 页面跳转
 <router-link :to="'content/123'">进入</router-link>
// 3 获取方式
this.$route.params.id // 输出123
   
1.2 编程式 this.$router.push

使用该方式传参时,需要在路由中提前配置好参数, 如:

// 1 路由配置
   {
     path: 'content/:id',
     name: 'Content',
     component: Content,
   },
// 2  页面触发js事件
 linkTo() {
    // 此处参数456可以通过动态变量替换
      this.$router.push('content/456') ;
   // 或
     this.$router.push({path: 'content/456'}) ;
 },
// 3 参数获取方式
this.$route.params.id // 输出456

url地址栏展示:

params传参url展示参数.png

2 params传参(url地址栏不显示参数)

params(不显示传参)也可以分为声明式和编程式两种,与方式一不同的是通过name进行传参,实现跳转;

2.1 声明式router-link

通过router-link组件的to属性实现

  // 1 路由配置
   {
       path: 'content',
       name: 'Content',
       component: Content,
    },
 // 2 页面跳转
<router-link :to="{name: 'Content', params: {id: 123}}">进入</router-link>
// 3 参数获取
this.$route.params.id // 输出123
2.2 编程式this.$router.push

使用该方式传值时,需要在路由中提前配置好参数,不过不需要在使用":/id"等类似方式传递参数,具体如下:

    // 1 路由配置
     {
       path: 'content',
       name: 'Content',
       component: Content,
      }
    // 2 js实现路由跳转
     this.$router.push({
        name: 'Content',
        params: {
          id: 123
        }
      })
// 3 参数获取
this.$route.params.id // 显示undefined

注意: 上述这种利用params不显示url传参的方式会导致在刷新页面的时候,传递的值会丢失;

3 query传参(显示参数)

query传参(显示参数)也可分为声明式和编程式两种方式

3.1 声明式 router-link

通过router-link组件的to属性实现,不过该方式传值的时候,需要子路由提前配置好路由别名(name属性),如

 // 1 路由配置
    {
       path: 'content',
       name: 'Content',
       component: Content,
     }
// 2 页面设置
 <router-link :to="{name: 'Content', query: {id: 123}}">进入</router-link>
// 3 参数获取
this.$route.query.id // 输出 123
3.2 编程式 this.$router.push

使用该方式传值的时候,需要路由提前配置好路由别名(name属性), 如:

   // 1 路由配置
    {
       path: 'content',
       name: 'Content',
       component: Content,
     }
  // 2 js跳转
      this.$router.push({
        name: 'Content',
        query: {
          id: 123
        }
      })
// 3 参数获取
this.$route.query.id  // 输出123

url地址栏展示:

query方式url展示.png

相关文章

  • vue - 路由带参跳转

    vue路由传参按照传参方式可划分为params传参和query传参; params传参分为在url中显示和影藏参数...

  • 路由带参跳转——vue

    点击子页面B的按钮,跳转到主页面A,同时携带子页面B中的信息,给主页面A。 在中跳转 子...

  • vue-router

    vue路由带参跳转,跳转后页面拿参一直有些混淆,今天用半小时屡清楚记录一下。 tip: >.< 啊!我终于分清了$...

  • Vue-Router

    1. 路由配置 默认路由跳转 在 new Router时可用的配置参数: 2.路由传参 Vue路由传参的几种方式 ...

  • 简单遍历vue2.0文档(五)

    11. vue-router 11.1 引用 11.2 配置路由文件 11.3 路由的跳转 11.4 路由的传参 ...

  • Vue 路由跳转相同路径页面不刷新

    Vue 路由跳转相同路径页面不刷新 vue 同一路由跳转不走生命周期,导致数据不更新不管是动态路由,还是传参 都不...

  • 解决vue路由跳转页面不刷新的问题

    解决vue路由跳转页面不刷新的问题 通过路由传参跳转界面,页面没有刷新解决方法:在 router-view 中加 ...

  • Vue router组件化开发总结

    Vue router就是Vue路由,是Vue不同组件之间跳转的重要方式。主要分为带参数跳转和不带参数跳转两种方式在...

  • Vue路由跳转+路由传参

    之前在原生JS的开发中,我们经常会用到根据某一状态进行页面的跳转。 比如:登录成功跳到首页,点击商品列表的某个商品...

  • Next.js 跳转传参并接收接参

    介绍路由传参,接参使用方法 传参 + 跳转页面接收参数 动态路由传参 + 跳转页面接收参数创建动态路由在pag...

网友评论

    本文标题:vue - 路由带参跳转

    本文链接:https://www.haomeiwen.com/subject/pwvkkctx.html