Frontend
Vue.js (5) 라우터
wrallee
2020. 4. 21. 00:37
1. 라우터 개념
<router-link to="/..."></router-link>
<router-view></router-view>
var routes = [ ... ] → 라우팅 정보 객체
var router = new VueRouter( ... ) → 라우터 객체
var app = new Vue( ... ) → 뷰 인스턴스
Vue( ... ).$mount() → $mount() API
2. 여러 컴포넌트로 화면 구성하기
A. 네스티드 라우터
상위 컴포넌트가 하위 컴포넌트를 포함하는 방식
최상위 ---라우터---> User컴포넌트 ---라우터---> Posts/Profile
path, component, children 활용
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Vue Nested Router</title>
</head>
<body>
<div id="app">
<router-view></router-view>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.2/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router@3.0.1/dist/vue-router.js"></script>
<script>
var User = {
template: `
<div>
User component
<router-view></router-view>
</div>
`
};
var UserProfile = { template: '<p>User Profile Component</p>' };
var UserPost = { template: '<p>User Post Component</p>' };
var routes = [
{
path: '/user',
component: User,
children: [
{
path: 'posts',
component: UserPost
},
{
path: 'profile',
component: UserProfile
}
]
}
]
var router = new VueRouter({
routes
});
var app = new Vue({
router
}).$mount('#app');
</script>
</body>
</html>
B. 네임드 뷰
같은 레벨에서 여러 개의 컴포넌트를 동시에 표시하는 방식
최상위 ---라우터(header)----> Header
┣----라우터(default)----> Body
┗----라우터(footer)----> Footer
path, components 활용
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Vue Named View Sample</title>
</head>
<body>
<div id="app">
<h1>Named View Example</h1>
<p>
<router-link to="/">Go to "/"</router-link>
<router-link to="/login">Go to "/login"</router-link>
</p>
<router-view name="header"></router-view>
<router-view></router-view>
<router-view name="footer"></router-view>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.2/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router@3.0.1/dist/vue-router.js"></script>
<script>
var Body = { template: '<div>This is Body</div>' };
var Header = { template: '<div>This is Header</div>' };
var Footer = { template: '<div>This is Footer</div>' };
var LoginBody = { template: '<div>Login-Body</div>' };
var LoginHeader = { template: '<div>Login-Header</div>' };
var LoginFooter = { template: '<div>Login-Footer</div>' };
var router = new VueRouter({
routes: [
{
path: '/',
components: {
default: Body,
header: Header,
footer: Footer
}
},
{
path: '/login',
components: {
default: LoginBody,
header: LoginHeader,
footer: LoginFooter
}
}
]
});
var app = new Vue({
router
}).$mount('#app');
</script>
</body>
</html>