zoukankan      html  css  js  c++  java
  • vue之路由传参三种基本方式

    现有如下场景,点击父组件的li元素跳转到子组件中,并携带参数,便于子组件获取数据。

    父组件中:

    <li v-for="article in articles" @click="getDescribe(article.id)">

    methods:

    方案一:

    getDescribe(id) {
    //   直接调用$router.push 实现携带参数的跳转
            this.$router.push({
              path: `/describe/${id}`,
            })

    方案一,需要对应路由配置如下:

    {
         path: '/describe/:id',
         name: 'Describe',
         component: Describe
       }

    很显然,需要在path中添加/:id来对应 $router.push 中path携带的参数。在子组件中可以使用来获取传递的参数值。

    this.$route.params.id

    方案二:

    父组件中:通过路由属性中的name来确定匹配的路由,通过params来传递参数。

     this.$router.push({
              name: 'Describe',
              params: {
                id: id
              }
            })

    对应路由配置: 这里可以添加:/id 也可以不添加,不添加数据会在url后面显示,不添加数据就不会显示

    {
         path: '/describe',
         name: 'Describe',
         component: Describe
       }

    子组件中: 这样来获取参数

    this.$route.params.id

    方案三:

    父组件:使用path来匹配路由,然后通过query来传递参数
    这种情况下 query传递的参数会显示在url后面?id=?

    this.$router.push({
              path: '/describe',
              query: {
                id: id
              }
            })

    对应路由配置:

    {
         path: '/describe',
         name: 'Describe',
         component: Describe
       }

    对应子组件: 这样来获取参数

    this.$route.query.id

    注意事项:

    1)、这里要特别注意在父组件中跳转到子组件使用  

    this.$router.push("/Home");//不传参
    this.$router.push({
    });//传参,参数以字段的形式加入到对象大括号{ }中

    2)、在子组件中获取参数的时候是

    this.$route.params.id

    this.$route.query.id

    注意是route而不是router


    转载署名:腹中有书气自华

    非商业性使用: 您不得将本作品用于商业目的。

    禁止演绎: 您不得修改、转换或者以本作品为基础进行创作。

    原文出处:https://segmentfault.com/a/1190000012393587?utm_source=tag-newest

    感谢原创博主:腹中有书气自华

    四、补充一种简单的路由写法

    有时候我们不想传参,直接使用此种方式跳转

    <router-link to="/backhome/emlserver" >
               <i class="el-icon-bell" style="font-size:30px;"> </i>
    </router-link>

    其中to="/backhome/emlserver" 指向自己已经配置好的路由界面

  • 相关阅读:
    软件工程个人作业01
    动手动脑
    大道至简感想终结篇
    课后作业
    反思
    课后作业
    不忘初心,方得始终
    课后作业
    沟通,让一切变得简单

  • 原文地址:https://www.cnblogs.com/yanl55555/p/11987151.html
Copyright © 2011-2022 走看看