我似乎无法在我的_slug.vue页面上渲染我的bandi图像。我能够从页面上的stradi渲染标题和内容。当我取出图像代码时,页面的文章标题和内容就很好了。
<div class="article__container">
<h1 class="article__title">{{ articles.title }}</h1>
<img :src="api_url + articles.image.url" class="article__img" />
<div
class="article__content"
v-html="$md.render(articles.content || 'No description provided')"
></div>
<div class="article__side-bar"><p>Sidebar</p></div>
</div>
<script>
import articleQuery from "~/apollo/queries/article/Article";
export default {
data() {
return {
api_url: process.env.strapiBaseUri
}
},
data: () => ({
articles: {},
}),
apollo: {
articles: {
prefetch: true,
query: articleQuery,
variables() {
return { slug: this.$route.params.slug };
},
update: data => data.articles[0]
}
}
};
</script>
答案 0 :(得分:0)
一种方法是在页面中使用head
方法并在其中使用变量
this
,并且可以head() {
return: {
title: this.title
meta: [
{
hid: `${this.title}-page-description`,
description: `${this.article.descriptioin}`
},
...
]
}
}
答案 1 :(得分:0)
很抱歉以前的答案(我在想其他地方)
这就是你可以做的
computed: {
updatedArticleImage() {
return this.articles.image.url.split('/uploads/').join('YOUR STRAPI URL/uploads/')
}
}
并将其用作添加到图像:src