vue-i18n 用于前端vue项目中,需要多语言切换的场景

  

 安装方法(npm)

npm install vue-i18n

  

 简单使用

   1、在vue项目的main.ts文件中实例化 i18n

import VueI18n from 'vue-i18n'

Vue.use(VueI18n)
 const i18n = new VueI18n({
    locale: 'zh', // 语言标识
    messages: {
       en: {
           test: {
             apple: 'apple',
          },
       },
       zh: {
          test: {
             apple: '苹果',
          },
       },
    },
 })
 

  

  2、把 i18n 挂载到 vue 根实例上

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

  3、在 HTML 模板中使用(简单示例)

 这里通过修改 i18n的 locale 的属性值来切换语言

<template>
<div>
{{ $t('test.apple') }}
<div>
<button @click="switchLang">切换英文</button>
</div>
</div>
</template> <script>
export default {
name: 'demo',
methods: {
switchLang() {
this.$i18n.locale = 'en'
},
},
}
</script> <style></style>

  4、效果如下

  在实际项目中,往往是需要大段的翻译内容,这时候,我们需要将翻译文本分类,分文件以便于管理

  具体结构可参考下图

  

  其中i18n.js是将i18n实例化的代码

import Vue from 'vue'
import VueI18n from 'vue-i18n'
import zh from './zh/index.js'
import en from './en/index.js'
Vue.use(VueI18n)
let locale = 'zh'
export default function(obj = {}) {
  return new VueI18n({
    locale, // 设置地区
    messages: { en, zh, ...obj }, // 设置地区信息
  })
}

  在main.js中挂载到vue实例上

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store' import createI18n from '@/assets/language/i18n.js' const i18n = createI18n() new Vue({
router,
store,
i18n,
render: h => h(App),
}).$mount('#app')

  

  en和zh文件夹中的index.js其实都一样,用webpack的api —— require.context 实现自动化导入模块

const languagesModule = require.context('./languageModule', true, /\.js$/)
const languages = languagesModule.keys().reduce((modules, modulePath) => {
const name = modulePath.replace(/^\.\/(.*)\.js+$/, '$1')
const value = languagesModule(modulePath)
modules[name] = value.default
return modules
}, {})
export default { ...languages }

  

  en和zh文件夹中的 languageModule 文件夹下的文件,都是以下的格式

export default {
  an_apple_a_day: '一天一个苹果,医生远离我',
}

  

  HTML模板中的使用情况及效果展示

<template>
<div>
{{ $t('test2.an_apple_a_day') }}
<div>
<button @click="switchLang">切换英文</button>
</div>
</div>
</template> <script>
export default {
name: 'demo',
methods: {
switchLang() {
this.$i18n.locale = 'en'
},
},
}
</script>

  

 vue-i18n变量赋值

  有时我们的不同翻译文本中有很多相同的语句,这时候我们可以把相同的提取出来,不同的用变量处理 或者 有时候我们的翻译中需要加入后端返回的数据,这时候也可以用到变量,

  变量用法

  用法很简单,这里只具体举一个例子展示

  

export default {  // 这里切记括号里变量左右不能有空格!!!
wait_and_try_again: '请等待{seconds}秒后再试',
}

  模板:

<p>{{ $t('test.wait_and_try_again', { seconds: 6 }) }}<p>

  效果:

  

vue-i18n 国际化语言切换的更多相关文章

  1. DataGrid 列头实现国际化语言切换

    <DataGrid> <DataGrid.Columns> <DataGridTextColumn Binding="{x:Null}" Width= ...

  2. vue 国际化i18n 多语言切换

    安装 npm install vue-i18n 新建一个文件夹 i18n ,内新建 en.js zh.js index.js 三个文件 准备翻译信息 en.js export default { ho ...

  3. Java 国际化 语言切换

      Java国际化 我们使用java.lang.Locale来构造Java国际化的情境. java.lang.Locale代表特定的地理.政治和文化.需要Locale来执行其任务的操作叫语言环境敏感的 ...

  4. vue中实现国际化--语言切换(转载)

    https://segmentfault.com/a/1190000011800593

  5. iOS - 国际化语言切换

    iOS国际化:如何切换语言   1.国际化就是将标签.提示信息等信息放到资源文件中,随着程序需要的语言提供对应的资源文件.以key/value对存储,每个资源的key值不变,value随着需求改变. ...

  6. Vue-i18n实现语言切换

    方法1 Vue — i18n 国际化 全局配置 安 装 1.直接引入js文件 <script src="https://unpkg.com/vue/dist/vue.js"& ...

  7. Element + Vue I18n动态import加载国际化语言包翻译文件

    需求 项目为多页应用,包含产品a.b.c.d.e,每个产品都有自己的翻译文件.一次加载所有翻译文件是极度不合理的.于是考虑动态加载. 实现 参考官方文档:延迟加载翻译 项目结构 │ ├── dist ...

  8. vue-i18n vue-cli项目中实现国际化 多语言切换功能 一

    vue-cli项目中引入vue-i18n 安装: npm install vue-i18n可参考vue-i18n官网文档 main.js中引入: import Vue from 'vue' impor ...

  9. iOS 语言切换、本地化,国际化

    什么是本地化处理? 本地化处理就是我们的应用程序有可能发布到世界的很多国家去,因为每个国家应用的语言是不一样的,所以我们要把我们的应用程序的语言要进行本地化处理一下. 本地化处理需要处理那些文件? ( ...

随机推荐

  1. docthis & VS code

    docthis & VS code JSDoc 3 http://usejsdoc.org/ http://usejsdoc.org/about-getting-started.html ht ...

  2. 十三香 & 香料

    十三香 & 香料 十三香原料组成不完全一致, 但有一些香料却是大家都会采用的: 草蔻.砂仁.肉豆蔻.肉桂.丁香. 花椒.大料.小茴香.木香.白芷. 山萘.良姜和姜 王守义十三香 http:// ...

  3. how to convert Map to Object in js

    how to convert Map to Object in js Map to Object just using the ES6 ways Object.fromEntries const lo ...

  4. vue & modal props & form data update bug

    vue & modal props & form data update bug OK <div> <BindModal :dialogBindVisible=&qu ...

  5. BGV再掀DeFi投资热潮,NGK全球启动大会圆满落幕

    此次全球启动大会的主题为"BGV再掀DeFi投资热潮,后市发展如何". 首先发言的是NGK灵石团队首席技术官STEPHEN先生,他先是对出席此次大会的嘉宾.到场的媒体记者以及NGK ...

  6. NGK——解决区块链用户之“难”

    自比特币诞生以来,区块链行业已发展十余年,而且在在金融.民生.司法存证.供应链协同.税务发票.版权保护等领域得到一定程度的应用,但大多属于边缘业务,以探索试点为主,应用深度和广度不足.为什么会这样?是 ...

  7. PBN转弯保护区作图回顾

    假期的最后一天,是该小结一下的时候了. 风螺旋有了自己中式风格的Logo,大家是否喜欢? 过去的春节假期,我们从学习CAD入手,回顾了风螺旋在PBN中的多种情况,画了很多的图,写了不少的文字,或许现在 ...

  8. uniapp 自定义弹窗组件

    先上效果: 组件源码:slot-modal.vue <template> <view class="modal-container" v-if="sho ...

  9. C++实现String类

    1 #include<iostream> 2 #include<cstring> 3 4 class String 5 { 6 public: 7 String(); 8 St ...

  10. Elasticsearch---DSL搜索实践

    Domain Specific Language 特定领域语言,基于JSON格式的数据查询,查询更灵活,有利于复杂查询 一.普通url路径参数搜索 数据准备 1.建立名字为 shop 的索引 2.手动 ...