Vue-router之路由参数传递

2018-09-10  本文已影响0人  王童孟

params

// client/config/routes.js
export default [
  {
    path: '/app/:id',
  }
]
// client/app.vue
<template>
  <div id="app">
    <router-link to="/app/123">app</router-link>
  </div>
</template>

点击 app 链接,跳转 todo 页面 ,本地url 路径 localhost:8000/app/123

通过 $route 可以拿到路由信息

// client/app.vue
export default {
  mounted () {
    console.log(this.$route)
  }
}
// 控制台
{name: "app", meta: {…}, path: "/app/123", hash: "", query: {…}, …}
fullPath:"/app/123"
hash:""
matched:[{…}]
meta:{title: "this is app", description: "xxx"}
name:"app"
params:{id: "123"}
path:"/app/123"
query:{}
__proto__:Object

props 传 params

通过这种方式,不需要 this.$route 的写法,它会和 vue-router 有一定的耦合,如果其升级,用法可能会变;如果组件使用了 this.$router 的写法,就不能作为单纯的组件拿到其他地方用,只能作为 route 配置中的 component 去用。

通过 props 的方式,实现了解耦,可以在其他地方使用组件,只需要传 props 即可。

// client/config/routes.js
export default [
  {
    path: '/app/:id', // 把 :id 作为 props 传到 Todo 中
    props: true, // 通过 props 来传 params
    component: Todo,
  }
]
export default {
  props: ['id'],
  mounted () {
    console.log(this.id) // 控制台 123
  }
}

props 指定值

// client/config/routes.js
export default [
  {
    path: '/app/:id', 
    props: {
      id: '456' 
    },
    component: Todo,
  }
]

props 函数

通过 query 指定 id

// client/config/routes.js
export default [
  {
    path: '/app/:id', 
    props: (route) => ({ id: route.query.b }) // 通过 query 指定 id
    component: Todo,
  }
]

query

在路径上直接添加,http://localhost:8000/app/123?a=123&b=456

通过 $route 拿到 query

query: {a: "123", b: "456"}

上一篇 下一篇

猜你喜欢

热点阅读