Maison >interface Web >Voir.js >Explication détaillée des fonctions de routage dans Vue3 : implémentation de sauts de routage pour les applications SPA
Vue3 est la dernière version de Vue, et sa fonction de routage a subi des changements majeurs par rapport à la version Vue2. En tant que l'un des outils importants pour la mise en œuvre d'applications à page unique (SPA), les fonctions de routage de Vue3 sont largement utilisées. Dans cet article, nous expliquerons en détail la fonction de routage dans Vue3, y compris les sauts de routage et leur implémentation.
1. Introduction à la fonction de routage de Vue3
La fonction de routage dans Vue3 se compose principalement de deux parties : l'instance de routage et le routeur. Parmi elles, l'instance de routage est une instance de Vue Router, qui est utilisée pour définir les routes et leurs chemins de saut ; et le routeur est chargé d'injecter l'instance de routage dans l'instance Vue pour la rendre efficace et permettre les sauts de routage.
2. Instance de routage
Dans Vue3, nous pouvons créer une instance de routage en appelant la fonction Vue Router. L'exemple de code est le suivant :
import { createRouter, createWebHistory } from 'vue-router'; const router = createRouter({ history: createWebHistory(), routes: [ { path: '/', component: Home }, { path: '/about', component: About }, { path: '/contact', component: Contact } ] })
Dans le code ci-dessus, . createRouter() peut accepter un objet de configuration, incluant deux propriétés : <code>history
et routes
. Parmi eux, history
est utilisé pour spécifier le mode de routage, et routes
est utilisé pour définir la table de routage. createRouter()
函数可以接受一个配置对象,包括history
和routes
两个属性。其中history
用于指定路由模式,routes
则用于定义路由表。
路由表是由路由配置对象数组组成的,数组中每个对象都表示一个路由的定义,包括以下几个属性:
path
:路由路径;component
:路由组件;name
:路由名称;meta
:路由元信息。在路由表中,我们可以使用path
和component
来定义路由路径和路由组件,示例代码如下:
import Home from '@/views/Home.vue'; import About from '@/views/About.vue'; import Contact from '@/views/Contact.vue'; const routes = [ { path: '/', component: Home }, { path: '/about', component: About }, { path: '/contact', component: Contact } ]
路由路径可以使用占位符来表示动态参数,示例代码如下:
const router = createRouter({ routes: [ { path: '/user/:id', component: User, props: true } ] })
上述示例中,路由路径/user/:id
中的冒号表示该路径可以匹配一个动态参数,我们可以通过props
属性来将动态参数作为组件属性传递到路由组件中。
在Vue3中,我们可以使用嵌套路由来组织应用的路由结构。嵌套路由是指路由路径包含多个层级的情况,示例代码如下:
const router = createRouter({ routes: [ { path: '/', component: Layout, children: [ { path: '', component: Home }, { path: '/about', component: About }, { path: '/contact', component: Contact } ] } ] })
上述示例中,我们在/
路径下定义了一个名为Layout
的路由组件,并将其作为嵌套路由的父级路径。Layout
组件中存在三个子路由,分别对应不同的路径。
路由守卫用于在路由跳转前或跳转后执行一些逻辑操作。在Vue3中,路由守卫主要分为全局守卫、路由守卫和组件守卫三类。
全局守卫有三种:
beforeEach
:在路由跳转前执行逻辑;beforeResolve
:在路由解析完成后,进行路由匹配前执行的逻辑;afterEach
:路由跳转后执行的逻辑。路由守卫分为两种:
beforeEnter
:在进入路由之前执行的逻辑;beforeLeave
:在离开路由之前执行的逻辑。组件守卫是针对组件级路由而言,包括以下几种:
beforeRouteEnter
:在组件进入路由前执行的逻辑;beforeRouteUpdate
:在组件更新路由前执行的逻辑;beforeRouteLeave
:在组件离开路由前执行的逻辑。三、路由器
在创建好路由实例后,我们需要将其注入到Vue实例中,使之生效。在Vue3中,我们可以通过调用createApp
函数来创建Vue实例,示例代码如下:
import { createApp } from 'vue'; import App from './App.vue'; import router from './router'; const app = createApp(App); app.use(router); app.mount('#app');
在上述代码中,我们使用createApp
函数创建Vue实例,并通过use
方法将路由实例router
注入到Vue实例中。
在Vue3中,我们可以通过调用router.push
方法实现路由跳转。router.push
方法接受一个参数,用于指定需要跳转的路由路径。示例代码如下:
import { RouterLink } from 'vue-router'; <RouterLink to="/">Home</RouterLink> <RouterLink to="/about">About</RouterLink> <RouterLink to="/contact">Contact</RouterLink>
在上述示例中,我们使用c3eee9878978ade0d6491433c64180cf
组件代替了Vue2版本中的b988a8fd72e5e0e42afffd18f951b277
path
: chemin de routage ; 🎜🎜component
: composant de routage ; 🎜🎜name
: nom de routage ; > : Méta-informations de routage. 🎜path
et component
pour définir les chemins de routage et les composants de routage. L'exemple de code est le suivant : 🎜rrreee🎜Le. le chemin de routage peut être utilisé comme espace réservé pour représenter les paramètres dynamiques, l'exemple de code est le suivant : 🎜rrreee🎜Dans l'exemple ci-dessus, les deux points dans le chemin de routage /user/:id
indiquent que le chemin peut correspondre un paramètre dynamique, nous pouvons transmettre l'attribut props
pour transmettre des paramètres dynamiques en tant que propriétés de composant au composant de routage. 🎜Layout
sous le /code> composant de routage de chemin et en faire le chemin parent de la route imbriquée. Il existe trois sous-routes dans le composant <code>Layout
, correspondant à différents chemins. 🎜beforeEach
: exécute la logique avant le saut de route ; 🎜🎜beforeResolve
: une fois l'analyse de la route terminée, avant la correspondance de la route ; Logique d'exécution ; 🎜🎜afterEach
: Logique exécutée après le saut de routage. 🎜beforeEnter
: logique exécutée avant d'entrer dans l'itinéraire ; 🎜🎜beforeLeave
: avant de quitter l'itinéraire ; Logique d'exécution. 🎜beforeRouteEnter
: logique exécutée avant que le composant n'entre dans la route ; 🎜🎜beforeRouteUpdate ; code> : Logique exécutée avant que le composant ne mette à jour la route ; 🎜🎜<code>beforeRouteLeave
: Logique exécutée avant que le composant ne quitte la route. 🎜
createApp
. L'exemple de code est le suivant : 🎜rrreee🎜Dans le code ci-dessus, nous utilisons la fonction createApp
pour. créez une instance Vue et injectez l'instance de routage router
dans l'instance Vue via la méthode use
. 🎜router.push
. La méthode router.push
accepte un paramètre pour spécifier le chemin de routage qui doit être sauté. L'exemple de code est le suivant : 🎜rrreee🎜Dans l'exemple ci-dessus, nous utilisons le composant c3eee9878978ade0d6491433c64180cf
au lieu du composant b988a8fd72e5e0e42afffd18f951b277
dans Vue2. version pour la mise en œuvre du saut d'itinéraire. 🎜🎜Ce qui précède est une explication détaillée de la fonction de routage dans Vue3, y compris l'utilisation d'instances de routage et de routeurs et la mise en œuvre de sauts de routage. En étudiant cet article, je pense que vous comprenez mieux la fonction de routage dans Vue3. 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!