vue 路由传参的三种基本模式

原文:https://www.cnblogs.com/EnSnail/p/8458001.html

路由是连接各个页面的桥梁,而参数在其中扮演者异常重要的角色,在一定意义上,决定着两座桥梁是否能够连接成功。

  在vue路由中,支持3中传参方式。

场景,点击父组件的li元素跳转到子组件中,并携带参数,便于子组件获取对应li的数据,显示相应的正确的内容。

父组件中:

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

  方案一:

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

          path: `/describe/${id}`,

        })// 方案一,需要对应路由配置如下:  {

    path: '/describe/:id',

    name: 'Describe',

    component: Describe

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

  方案二:

// 父组件中:通过路由属性中的name来确定匹配的路由,通过params来传递参数。this.$router.push({

          name: 'Describe',

          params: {

            id: id

          }

        })// 对应路由配置: 注意这里不能使用:/id来传递参数了,因为父组件中,已经使用params来携带参数了。  {

    path: '/describe',

    name: 'Describe',

    component: Describe

  }//子组件中: 这样来获取参数$route.params.id

  方案三:

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

    this.$router.push({

          path: '/describe',

          query: {

            id: id

          }

        })// 对应路由配置:  {

    path: '/describe',

    name: 'Describe',

    component: Describe

  }// 对应子组件: 这样来获取参数$route.query.id// 这里要特别注意 在子组件中 获取参数的时候是$route.params 而不是$router 这很重要~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容