<router-link to="demo2">demo2</router-link>
使用 v-bind 的写法
<router-link :to="‘demo2‘">demo2</router-link>
<!-- 也可以用{}包裹对应的path或name -->
<router-link :to="{ name: ‘demo2‘ }">demo2</router-link>
传参
<router-link :to="{ name: ‘demo2‘, params: { userId: 123 }}">demo2</router-link>
这里传参需要在 router.js 中对 demo2 的路径进行配置,在 path 中 demo2 后添加通配符 : 和对应的 userId,如下:
{
path: ‘/demo2/:userId‘,
name: ‘demo2‘,
component: demo2
},
配置完成后,页面跳转的结果就为 /demo2/123
在 mounted 钩子中使用 this.$route.params.xx. 获取传过来的参数,如下:
mounted () {
alert(this.$route.params.userId)
}
传入地址键值对
<router-link :to="{ path: ‘demo2‘, query: { plan: ‘private‘ }}">demo2</router-link>
页面跳转的结果为 /demo2?plan=private,这里不用在 router.js 里配置路径
在新页面中获取到传过来的地址键值对 plan,可以在 mounted 钩子中使用 this.$route.plan.xx. 获取传过来的地址键值对,如下:
mounted () {
alert(this.$route.query.plan)
}
<button @click="toURL">跳转页面</button>
methods:{
toURL(){
this.$router.push({ path: ‘/demo2‘ })
}
}
传参的写法
methods:{
toURL(){
this.$router.push({ name: ‘demo2‘, params: { userId: 123 }})
}
}
传入地址键值对
methods:{
toURL(){
this.$router.push({ name: ‘demo2‘, params: { userId: 123 }, query: { plan: ‘private‘ } })
}
}