반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 보정명령
- 전자소송
- 이더리움
- blockchain
- 소액임금체불
- Laravel
- javascript
- 개인사업자
- 홈택스
- 인민공원
- Java
- elasticSearch
- auth
- cartalyst
- Bootstrap
- Blade
- Python
- 체당금
- Sentinel
- Tutorial
- vue
- 코로나19
- Eclipse
- php
- 코로나
- reactnative
- win32
- 사업자계좌
- 당사자표시정정신청서
- as후기
Archives
- Today
- Total
그냥 사는 이야기
vue router 기초 본문
반응형
SPA
에서는 sub path에 대한 관리를 별도로 해줘야 합니다. 말그대로 single page 이므로 이후의 page란 없는 것 입니다. 이를 위해 vue 에서는 vue-router
를 사용합니다.
router 내용 선언
vue-router가 SPA에서 다른 경로의 component를 가르키는 기본 형태는 아래와 같습니다.
router/index.js
{
path: '/about',
name: 'about',
// route level code-splitting
// this generates a separate chunk (about.[hash].js) for this route
// which is lazy-loaded when the route is visited.
component: () => import(/* webpackChunkName: "about" */ '../views/About')
}
위의 주석을 살펴보면 SPA이므로 처음 로딩부터 모든 component 요소를 가지고 있기보다는 lazy-loaded를 하기 위해 () function
으로 감싼 것을 볼수 있습니다. 그리고 그 내용은 router/index.js
경로에서 부터 상대경로를 넣어주면 됩니다.
route 시키기
이제 about 컴포넌트를 보여주기 위해서는 기존처럼 href 같은 형태가 아닌 vue-route의 기능을 사용하여 호출되어야 합니다. 그러기 위해 drawer의 template에서 예를 살펴보겠습니다.
<v-list-item link>
<v-list-item-action>
<v-icon>mdi-contact-mail</v-icon>
</v-list-item-action>
<v-list-item-content>
<v-list-item-title>About contact</v-list-item-title>
</v-list-item-content>
</v-list-item>
1. $router.push() 사용하기
<v-list-item link @click="$router.push('/about')">
이런 형태로 직접 component에 명시된 /about
경로를 바로 가르킬 수 있습니다.
<v-list-item link @click="$router.push({name: 'about', params: { userId: 123 }})">
name이 about인 component를 찾아서 경로로 가르킬 수 있습니다. 이렇게 사용할 경우는 뒤에 parameter를 추가로 넣어 줄 수 있는 장점 뿐만 아니라 조금 더 명시적으로 가르켜 사용하도록 해줍니다.
2. router-link or router
또 다른 방법으로는 아래와 같은 문법도 있습니다.
router :to="{name: 'about'}"
혹은 router-link
를 사용할 수 있습니다.
<router-link :to="{name: 'about'}">
'Development > Web' 카테고리의 다른 글
Vue에서 error: Unexpected console statement (no-console) (0) | 2020.12.15 |
---|---|
vuejs, vuetify2 에서 polyfill 적용하려면 (0) | 2020.12.11 |
Laravel 5.3 Blog System - Admin Dashboard - Edit, Delete (0) | 2020.01.23 |
Laravel 5.3 Blog System - Admin Dashboard - Create, Store (0) | 2020.01.23 |
Laravel 5.3 Blog System - Admin Dashboard - All Posts (0) | 2020.01.23 |
Comments