问答

vue i18n 渲染失敗?

作者:admin 2021-04-09 我要评论

嗨大家好,在 vue i18n 遇到問題 main.js import Vue from 'vue'import App from '@/App.vue'import VueI18n from 'vue-i18n'import lang from '@/utils/lang'.....

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

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

###

{{ $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, // 设置地区信息
})

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • nginx响应速度很慢

    nginx响应速度很慢

  • 点击选中的多选框,会在已选那一栏显示

    点击选中的多选框,会在已选那一栏显示

  • PHP 多态的理解

    PHP 多态的理解

  • 关于C语言中static的问题

    关于C语言中static的问题

腾讯云代理商
海外云服务器