Redirection et alias
Redirection
Les redirections peuvent aussi être faites depuis la configuration de routes
. Pour rediriger /a
vers /b
:
const router = new VueRouter({
routes: [
{ path: '/a', redirect: '/b' }
]
})
La redirection peut également être effectuée en ciblant une route nommée :
const router = new VueRouter({
routes: [
{ path: '/a', redirect: { name: 'foo' }}
]
})
Ou on peut même utiliser une fonction pour les redirections dynamiques :
const router = new VueRouter({
routes: [
{ path: '/a', redirect: to => {
// la fonction reçoit la route cible en tant qu'argument
// retournez le chemin vers la nouvelle route ici.
}}
]
})
Notez que les intercepteurs de navigation ne sont pas appliqués sur les routes d'où à lieu la redirection mais uniquement sur les routes cibles. Dans l'exemple ci-dessous, ajouter une interception beforeEnter
ou beforeLeave
à la route /a
n'aura aucun effet.
Pour d'autres utilisations avancées, jetez un œil à cet exemple.
Alias
Une redirection signifie que si l'utilisateur visite /a
, l'URL va être remplacé par /b
et concordé avec /b
. Mais qu'est-ce qu'un alias ?
** Un alias de /a
en tant que /b
signifie que lorsque l'utilisateur va visiter /b
, l'URL va rester /b
, mais la concordance va se faire comme si l'utilisateur visitait /a
.**
La phase du dessus peut être exprimée dans la configuration de la route de la manière suivante :
const router = new VueRouter({
routes: [
{ path: '/a', component: A, alias: '/b' }
]
})
Un alias vous donne la liberté d'associer une structure d'interface utilisateur à un URL arbitraire, au lieu d'être contraint par une configuration de structure.
Pour d'autres utilisations avancées, jetez un œil à cet exemple.