[英]How to pass parameters on redirecting using Vue Router
我在这里有一个示例 Vue 路由器,它在访问具有特定 ID 的表单之前先处理登录:
router = new VueRouter({
routes: [
{path: '/form/:id', redirect: '/login'},
{path: '/login', name: 'Login', component: Login}
]
});
有没有办法让登录仍然可以访问传递的 :id 参数,因为当我运行http://localhost:8080/form/c101-101时,它直接重定向到登录组件,当我尝试记录 this.$route。登录组件中的 params.id 是undefined 。 有没有办法可以在重定向时传递 :id ?
根据 Vue 文档,您可以使用函数进行动态重定向。
这是一个使用参数(例如yourdomain.com/:yourParam
)并重定向到另一个 URL 的示例,使用参数( yourParam
)作为查询字符串( yourdomain.com/your/route?yourQueryString=:yourParam
):
redirect: to => ({
name: "your-named-route",
query: { yourQueryString: to.params.yourParam },
}),
注意:此语法使用 ES6。
您可以在登录路由中将 /:id 设为可选,如下所示:-
router = new VueRouter({
routes: [
{path: '/form/:id', redirect: '/login/:id'},
{path: '/login/:id?', name: 'Login', component: Login}
]
});
使用上面的代码片段,您将在登录组件中获得 this.$route.params.id。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.