mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-18 11:45:11 +00:00
53 lines
822 B
Vue
53 lines
822 B
Vue
|
|
<template>
|
|
<div class="container">
|
|
<h1>{{ post.title }}</h1>
|
|
<pre>{{ post.body }}</pre>
|
|
<p><nuxt-link to="/posts">Back to the list</nuxt-link></p>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import axios from 'axios'
|
|
|
|
export default {
|
|
async asyncData({ params }) {
|
|
// We can use async/await ES6 feature
|
|
const { data } = await axios.get(`https://jsonplaceholder.typicode.com/posts/${params.id}`)
|
|
return { post: data }
|
|
},
|
|
head() {
|
|
return {
|
|
title: this.post.title
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
.container {
|
|
width: 70%;
|
|
margin: auto;
|
|
text-align: center;
|
|
padding-top: 100px;
|
|
}
|
|
ul {
|
|
list-style-type: none;
|
|
padding: 0;
|
|
}
|
|
ul li {
|
|
border: 1px #ddd solid;
|
|
padding: 20px;
|
|
text-align: left;
|
|
}
|
|
ul li a {
|
|
color: gray;
|
|
}
|
|
p {
|
|
font-size: 20px;
|
|
}
|
|
a {
|
|
color: #41B883;
|
|
}
|
|
</style>
|