때로는 라우트가 활성화될 때 서버에서 데이터를 가져와야 한다.
(ex. 사용자 프로필을 렌더링하기 전에 서버에서 사용자의 데이터를 가져와야 할 때)
이때, 두 가지 방법을 사용할 수 있다.
이 방법을 사용하면 들어오는 컴포넌트를 즉시 탐색하고 렌더링하며 컴포넌트의 created
훅에서 데이터를 가져온다.
네트워크를 통해 데이터를 가져 오는 동안 로드 상태를 표시 할 수 있는 기회를 제공하며 각 뷰 마다 로드를 다르게 처리 할 수도 있다.
$route.params.id
를 기반으로 한 게시물의 데이터를 가져와야하는 Post 컴포넌트가 있다고 가정 할 경우 예시 :
<template>
<div class="post">
<div class="loading" v-if="loading">
Loading...
</div>
<div v-if="error" class="error">
{{ error }}
</div>
<div v-if="post" class="content">
<h2>{{ post.title }}</h2>
<p>{{ post.body }}</p>
</div>
</div>
</template>
export default {
data () {
return {
loading: false,
post: null,
error: null
}
},
created () {
// 뷰가 생성되고 데이터가 이미 감시 되고 있을 때 데이터를 가져옴
this.fetchData()
},
watch: {
// 라우트가 변경되면 메소드 재 호출
'$route': 'fetchData'
},
methods: {
fetchData () {
this.error = this.post = null
this.loading = true
// `getPost`를 데이터 가져오기 위한 유틸리티/API 래퍼로 변경
getPost(this.$route.params.id, (err, post) => {
this.loading = false
if (err) {
this.error = err.toString()
} else {
this.post = post
}
})
}
}
}
이 접근 방식을 사용하면 실제로 새 경로로 이동하기 전에 데이터를 가져온다.
들어오는 컴포넌트에서 beforeRouteEnter
가드에서 데이터를 가져올 수 있으며 페치가 완료되면 next만 호출 할 수 있다.
export default {
data () {
return {
post: null,
error: null
}
},
beforeRouteEnter (to, from, next) {
getPost(to.params.id, (err, post) => {
next(vm => vm.setData(err, post))
})
},
watch: {
// 라우트가 변경되면 메소드 재 호출
'$route': 'fetchData'
},
methods: {
fetchData () {
this.error = this.post = null
this.loading = true
// `getPost`를 데이터 페치 유틸리티/API 래퍼로 변경
getPost(this.$route.params.id, (err, post) => {
this.loading = false
if (err) {
this.error = err.toString()
} else {
this.post = post
}
})
}
}
}