프론트 엔드 기술의 지속적인 개발로 인해 이제 SPA(단일 페이지 애플리케이션) 개발 방법을 채택하는 애플리케이션이 점점 더 많아지고 있습니다. 프런트 엔드 개발을 위한 중요한 도구 중 하나인 Vue.js는 점점 더 많은 개발자가 선호하는 프레임워크 중 하나가 되었습니다. 그리고 Vue.js를 사용하여 단일 페이지 애플리케이션을 구축하면 Vue Router가 탄생합니다.
Vue Router는 Vue.js의 공식 라우팅 관리자입니다. 이를 통해 간단한 구성을 통해 애플리케이션 라우팅 규칙을 정의하고 이러한 규칙을 구성 요소에 매핑하여 단일 페이지 애플리케이션에서 페이지 점프 효과를 얻을 수 있습니다. 이 글에서는 Vue Router를 사용하는 단계를 소개합니다.
Vue Router를 사용하려면 먼저 프로젝트에 설치해야 합니다. npm 또는 원사를 통해 설치할 수 있습니다:
npm install vue-router --save
또는
yarn add vue-router
Vue Router의 핵심 부분은 라우팅 인스턴스를 생성하는 것입니다. 일반적으로 라우팅 구성 파일 router.js(또는 다른 이름)에서 이 인스턴스를 생성합니다. 먼저 Vue 및 Vue Router를 소개해야 합니다:
import Vue from 'vue' import VueRouter from 'vue-router' Vue.use(VueRouter)
그런 다음 라우팅 규칙을 정의해야 합니다:
const routes = [ { path: '/', component: Home }, { path: '/about', component: About }, { path: '/contact', component: Contact } ]
여기서 경로는 라우팅 규칙을 포함하는 배열입니다. 각 라우팅 규칙은 경로와 구성 요소라는 두 가지 특성을 포함하는 개체입니다. 그 중 path는 URL의 경로를 나타내고, 컴포넌트는 경로에 해당하는 컴포넌트입니다.
마지막으로 Vue Router 인스턴스를 생성하고 정의한 경로 규칙을 전달해야 합니다.
const router = new VueRouter({ mode: 'history', routes })
인스턴스를 생성할 때 모드 및 경로 등과 같은 일부 속성을 구성할 수 있습니다. 경로 관련 매개변수를 지정합니다.
루트 인스턴스에서 라우팅 인스턴스(Vue Router 객체)를 사용할 것이므로 인스턴스를 루트 인스턴스에 마운트해야 합니다. 예:
new Vue({ router, render: h => h(App) }).$mount('#app')
여기에서는 라우팅 인스턴스(예: 라우터)를 루트 Vue 인스턴스에 전달하고 루트 구성 요소(예: 앱)를 애플리케이션의 #app 노드에 렌더링합니다.
Vue 라우터 인스턴스를 생성하고 이를 루트 Vue 인스턴스에 탑재하면 Vue 구성 요소 간의 경로 탐색을 수행할 수 있습니다.
Vue Router에는 라우터 보기와 라우터 링크라는 두 가지 중요한 구성 요소가 있습니다. Router-view는 라우팅 구성 요소의 특정 내용을 표시하는 데 사용되는 반면, router-link는 서로 다른 경로 간 탐색을 위한 링크입니다.
예를 들어 애플리케이션 루트 구성 요소에서 router-view를 사용하여 다양한 경로에 해당하는 구성 요소를 표시할 수 있습니다.
<template> <div id="app"> <nav> <router-link to="/">Home</router-link> <router-link to="/about">About</router-link> <router-link to="/contact">Contact</router-link> </nav> <router-view></router-view> </div> </template>
여기에서는 router-link 태그를 통해 일부 라우팅 링크를 만들었습니다. 라우팅 링크를 클릭하면 Vue Router는 자동으로 URL을 업데이트하고 라우팅 구성 요소를 라우터 보기로 렌더링합니다.
Vue 라우터는 탐색 중 논리를 처리하기 위해 몇 가지 후크 기능(라우팅 가드)도 제공합니다. 이러한 라우팅 후크는 전역적으로 또는 경로별로 사용할 수 있습니다.
예를 들어 beforeEach 전역 라우팅 후크 함수에서 사용자의 로그인 확인 논리를 구현할 수 있습니다.
router.beforeEach((to, from, next) => { if (to.meta.requireAuth) { if (store.getters.isAuthenticated) { next() } else { next({ path: '/login', query: { redirect: to.fullPath } }) } } else { next() } })
위 코드에서는 beforeEach 라우팅 후크를 사용하여 사용자가 인증되었는지 확인합니다. 사용자가 인증된 경우 탐색을 계속하고, 그렇지 않으면 사용자를 로그인 페이지로 리디렉션합니다.
beforeEach 라우팅 후크 외에도 Vue Router는 라우팅 탐색 프로세스에 사용되는 다른 후크 기능도 제공합니다. 예를 들어 beforeRouteEnter는 새 경로를 입력하기 전에 구성 요소 인스턴스 개체를 얻는 데 사용됩니다. beforeRouteUpdate는 현재 구성 요소를 재사용할 때 구성 요소 인스턴스 객체를 얻는 데 사용됩니다. beforeRouteLeave는 탐색이 현재 구성 요소를 떠날 때 인스턴스 개체를 얻는 데 사용됩니다.
위는 Vue Router를 사용하는 단계입니다. Vue Router는 개발 프로세스를 단순화하고 애플리케이션 성능과 사용자 경험을 향상시키는 데 도움이 될 수 있는 매우 풍부한 구성 옵션 및 라우팅 후크 기능 세트를 제공합니다.
위 내용은 Vue Router 사용 단계를 소개하는 기사의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!