vue i18n 渲染失敗?

嗨大家好,在 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成功...

阅读 3.9k
1 个回答

{{ $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, // 设置地区信息
})
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题