mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-23 22:25:12 +00:00
50 lines
984 B
Vue
50 lines
984 B
Vue
|
<template>
|
||
|
<div class="container">
|
||
|
<p>About Page</p>
|
||
|
<p>It should take 5 seconds for the loader to disappear</p>
|
||
|
<p>It should take 5 seconds for the route to change after you
|
||
|
<span class="link" @click="goToFinal">click here</span></p>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
export default {
|
||
|
loading: false,
|
||
|
asyncData() {
|
||
|
return new Promise((resolve) => {
|
||
|
setTimeout(function () {
|
||
|
resolve({})
|
||
|
}, 1000)
|
||
|
})
|
||
|
},
|
||
|
mounted() {
|
||
|
setTimeout(() => {
|
||
|
// Extend loader for an additional 5s
|
||
|
this.$nuxt.$loading.finish()
|
||
|
}, 5000)
|
||
|
},
|
||
|
methods: {
|
||
|
goToFinal() {
|
||
|
// Start loader immediately
|
||
|
this.$nuxt.$loading.start()
|
||
|
// Actually change route 5s later
|
||
|
setTimeout(() => {
|
||
|
this.$router.push('/final')
|
||
|
}, 5000)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style scoped>
|
||
|
.link {
|
||
|
cursor: pointer;
|
||
|
text-decoration: underline;
|
||
|
}
|
||
|
.container {
|
||
|
font-size: 20px;
|
||
|
text-align: center;
|
||
|
padding-top: 100px;
|
||
|
}
|
||
|
</style>
|