>웹 프론트엔드 >View.js >Vue Router에서 경로 일치는 어떻게 이루어지나요?

Vue Router에서 경로 일치는 어떻게 이루어지나요?

王林
王林원래의
2023-07-22 14:49:061714검색

Vue Router는 Vue.js의 공식 라우팅 관리자입니다. 단일 페이지 애플리케이션에서 페이지 간 전환 및 이동을 도와 웹 애플리케이션의 사용자 경험을 향상시킬 수 있습니다. Vue Router의 핵심 기능 중 하나는 경로 일치입니다. 이 기사에서는 Vue Router에서 경로 일치가 수행되는 방법을 소개합니다.

Vue Router에서는 라우팅 테이블(Route Table)을 통해 경로 매칭이 완료됩니다. 라우팅 테이블은 개발자가 정의하며 각 라우팅 테이블 항목에는 경로, 해당 구성 요소 및 관련 구성이 포함됩니다. Vue Router 인스턴스를 생성할 때 라우팅 구성 객체를 전달하여 라우팅 테이블을 정의할 수 있습니다.

import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from './components/Home.vue'
import About from './components/About.vue'
import NotFound from './components/NotFound.vue'

Vue.use(VueRouter)

const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About },
  { path: '*', component: NotFound },
]

const router = new VueRouter({
  routes
})

export default router

위 코드에는 세 개의 라우팅 테이블 항목이 정의되어 있습니다. { path: '/' }는 루트 경로를 나타내며, 해당 구성 요소는 Home입니다. { path: '/about' }는 경로는 /about이고 해당 구성 요소는 정보입니다. { 경로: '*' }는 일치하지 않는 다른 경로를 나타내며 해당 구성 요소는 찾을 수 없음. { path: '/' } 表示根路径,对应的组件为 Home{ path: '/about' } 表示路径为 /about,对应的组件为 About{ path: '*' } 表示其他未匹配到的路径,对应的组件为 NotFound

在运行时,当用户访问某个路径时,Vue Router 会根据当前的路径进行匹配,找到对应的路由表项。Vue Router 提供了两种匹配模式:基于 Hash(Hash Mode)和基于 History(History Mode)。

基于 Hash 的匹配模式通过监听 location.hash 的变化来实现路由匹配。例如,当用户访问 /about 路径时,location.hash 的值会变为 #/about,Vue Router 会根据这个 hash 值来匹配到对应的路由表项,并加载相应的组件。

基于 History 的匹配模式使用 HTML5 的 History API,通过监听 location.pathname 的变化来实现路由匹配。例如,当用户访问 /about 路径时,location.pathname 的值会变为 /about,Vue Router 会根据这个路径名来匹配到对应的路由表项,并加载相应的组件。

Vue Router 内部实现了一个路由匹配的算法。它会将路由路径按照 / 进行分割,然后依次进行匹配。对于每个路径段(path segment),Vue Router 会依次判断是否匹配当前路由表项的路径段。

路由匹配支持动态参数,我们可以在路由表项的路径中使用动态参数。例如,{ path: '/user/:id' } 中的 :id 就是一个动态参数。在实际的匹配过程中,当路径中的 id

런타임에 사용자가 특정 경로에 액세스하면 Vue Router는 현재 경로와 일치하고 해당 라우팅 테이블 항목을 찾습니다. Vue Router는 해시 기반(해시 모드)과 기록 기반(기록 모드)의 두 가지 일치 모드를 제공합니다.

해시 기반 일치 모드는 location.hash의 변경 사항을 모니터링하여 경로 일치를 구현합니다. 예를 들어, 사용자가 /about 경로에 액세스하면 location.hash의 값이 #/about로 변경되고 Vue Router는 이 해시 값을 사용하여 해당 라우팅 테이블 항목을 일치시키고 해당 구성 요소를 로드합니다.

기록 기반 일치 모드는 HTML5의 History API를 사용하여 location.pathname의 변경 사항을 모니터링하여 경로 일치를 구현합니다. 예를 들어, 사용자가 /about 경로에 액세스하면 location.pathname의 값이 /about으로 변경되고 Vue Router는 다음을 사용합니다. 이 경로 이름은 해당 라우팅 테이블 항목과 일치하고 해당 구성 요소를 로드합니다.

Vue Router는 내부적으로 경로 일치 알고리즘을 구현합니다. /에 따라 라우팅 경로를 분할한 다음 순서대로 일치시킵니다. 각 경로 세그먼트에 대해 Vue Router는 현재 라우팅 테이블 항목의 경로 세그먼트와 일치하는지 여부를 결정합니다. 🎜🎜경로 일치는 동적 매개변수를 지원합니다. 라우팅 테이블 항목의 경로에 동적 매개변수를 사용할 수 있습니다. 예를 들어 { path: '/user/:id' }:id는 동적 매개변수입니다. 실제 일치 과정에서 경로의 id 부분이 변경되면 Vue Router는 다시 일치하고 동적 매개변수의 값을 구성 요소에 전달합니다. 🎜🎜경로 일치 외에도 Vue Router는 리디렉션(Redirect) 및 별칭(Alias)과 같은 다른 일치 조건도 지원합니다. 이러한 일치 조건을 구성하면 라우팅 동작을 보다 유연하게 제어할 수 있습니다. 🎜🎜요약하자면 Vue Router의 경로 일치는 라우팅 테이블을 통해 수행됩니다. 라우팅 테이블은 개발자가 정의하며 각 라우팅 테이블 항목에는 경로와 해당 구성 요소 및 관련 구성이 포함됩니다. 런타임 시 Vue Router는 현재 경로와 일치하고 해당 라우팅 테이블 항목을 찾은 다음 해당 구성 요소를 로드합니다. 경로 일치는 동적 매개변수를 지원하며 경로의 동작은 다른 일치 조건을 구성하여 제어할 수 있습니다. 🎜🎜이 글을 통해 독자들이 Vue Router의 경로 매칭 프로세스를 이해하고 실제 프로젝트에서 유연하게 사용할 수 있기를 바랍니다. 🎜

위 내용은 Vue Router에서 경로 일치는 어떻게 이루어지나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.