我有一个带有 vue-meta 的 vue2 项目,我有 vue-i18n 来本地化该项目。
在我的浏览器书签中,没有显示网页的标题。而是显示变量。在 Google Analytics 中查看时出现同样的问题,似乎显示的是我的变量而不是变量中的值。
这是我的 Home 组件的代码片段:
name: 'Home',
metaInfo () {
return {
title: this.$t("home.meta.title"),
meta: [{
name: "description",
content: this.$t("home.meta.descriptioncontent")
}, {
name: "keywords",
content: this.$t("home.meta.keywordscontent")
},
{ property: 'og:title', content: this.$t("home.meta.title")},
{ property: 'og:site_name', content: 'www.examplesite.se'},
{ property: 'og:description', content: this.$t("home.meta.descriptioncontent")},
{ property: 'og:type', content: 'Home'},
{ property: 'og:url', content: 'https://examplesite.se/'},
{ property: 'og:image', content: 'https://www.examplesite.se' + '/img/' + 'example_logo_social.png'}
]
}
},
data() {
return {
fimagefolder: '../../Images/',
bimagefolder: '../../fImages/',
};
},
所以 this.$t("home.meta.title") 变量存储瑞典语和英语翻译。当在网站内时,它会显示两种语言的正确标题,但谷歌分析只显示“home.meta.title”。据我了解,由于未加载任何脚本,爬虫程序看不到我的变量值?有任何想法吗?
最佳答案
最好能看到你的一些代码,看看你是如何设置的,否则我们会一头雾水,很难提供帮助。因此,这与其说是答案,不如说是评论,但我正在分享一些可能有帮助但不适合评论的代码。
我假设您正在使用 vue-i18n 并且我的猜测是您将 vueMeta 定义为一个对象。而如果将其定义为函数,则可以访问其他组件数据,包括 this.$t
.它应该像这样一起工作:
<template>
<div>
<p>The title of this page should be 'Translated Title'.</p>
</div>
</template>
<script>
export default {
metaInfo () {
return {
title: this.$t('title')
}
}
}
</script>
<i18n>
{
"en": {
"title": "Translated Title"
}
}
</i18n>
关于vue.js - Vue meta i18n 变量名显示而不是值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68667197/