vue i18n 渲染失敗?

发布于 2022-09-12 23:07:47 字数 766 浏览 14 评论 0

嗨大家好,在 vue i18n 遇到問題

main.js

import Vue from 'vue'
import App from '@/App.vue'
import VueI18n from 'vue-i18n'
import lang from '@/utils/lang'
...略

Vue.use(VueI18n)
Vue.config.productionTip = false

const i18n = new VueI18n({
  locale: 'cn',
  message: lang, 
})

new Vue({
  i18n,
  router,
  store,
  render: h => h(App),
}).$mount('#app')

lang.js

const lang = {
    cn: {
        setting: {
            webTitle: 'Studio',
        }
    },
    en: {
        
    },
}

export default lang

在 template 使用嘗試渲染時

{{ $t('setting.webTitle') }}

結果為

setting.webTitle

應該要是

Studio

這是怎麼回事?
確定有將i18n import成功...

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

以酷 2022-09-19 23:07:47

{{ $t('setting.webTitle') }} -> {{ $t('message.setting.webTitle') }}

重新仔细的对比了下官方文档和你的代码

const messages = {
  en: {
    message: {
      hello: 'hello world'
    }
  },
  ja: {
    message: {
      hello: 'こんにちは、世界'
    }
  }
}

// 通过选项创建 VueI18n 实例
const i18n = new VueI18n({
  locale: 'ja', // 设置地区
  messages, // 设置地区信息
})

也就是说message应该是少写了一个s

const i18n = new VueI18n({
  locale: 'cn', // 设置地区
  messages: lang, // 设置地区信息
})
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文