vue用i18n实现多语言切换国际化附源码下载

来源:程序思维浏览:2227次
vue用i18n实现多语言切换国际化附源码下载

如果项目需要多语言的支持,我们需要做国际化,使用 vue-i18n 来实现多语言的界面

安装

$ npm install vue-i18n --save

在入口main.js文件配置使用

import Vue from 'vue'
import VueI18n from 'vue-i18n'

Vue.use(VueI18n);
/*---------基本使用-----------*/
const i18n = new VueI18n({
  locale: 'CN',    // 语言标识
  messages : {
    en: {
      message: {
        hello: 'hello world'
      }
    },
    cn: {
      message: {
        hello: '你好、世界'
      }
    }
  }
})
/*---------使用语言包-----------*/
const i18n = new VueI18n({
  locale: 'CN',    // 语言标识
  messages: {
    'CN': require('./assets/common/lang/cn'),   // 中文语言包
    'EN': require('./assets/common/lang/en')    // 英文语言包
  },
})

/*---------语言包内部语法star-----------*/
export const  message = {
      language:'语言',
      hello: '你好,世界'
}
/*---------语言包内部语法end-----------*/

/*---------挂载全局使用-----------*/
new Vue({
  el: '#app',
  i18n,
  router,
  template: '<App/>',
  components: { App }
})

/*---------vue组件模板的使用-----------*/
<template>
        <p>{{ $t("message.hello") }}</p>
    </template>

单独组件的使用

在单个vue组件中使用,要用到i18n自定义块,需要配置webpack文件webpack.base.conf.js


module.exports = {
  // ...
  module: {
    rules: [
      {
        test: /\.vue$/,
        loader: 'vue-loader',
        options: {
          loaders: {
            // you need to specify `i18n` loaders key with `vue-i18n-loader` (https://github.com/kazupon/vue-i18n-loader)
            i18n: '@kazupon/vue-i18n-loader'
          }
        }
      },
      // ...
    ]
  },
  // ...
}


示例

<i18n>
{
  "en": {
    "hello": "hello world!"
  },
  "ja": {
    "hello": "你好,世界!"
  }
}
</i18n>

<template>
  <div id="app">
    <label for="locale">locale</label>
    <select v-model="locale">
      <option>en</option>
      <option>ja</option>
    </select>
    <p>message: {{ $t('hello') }}</p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () { return { locale: 'en' } },
  watch: {
    locale (val) {
      this.$i18n.locale = val
    }
  }
}
</script>


关于语言包,我们有几种方式,一种是每个语言包一个独立的js放到项目里, 或者将语言的对照写在 .vue 文件里, 或者加载远程的JSON语言包
我们的后台界面需要支持的语言通常不多,更新也不会非常的频繁,所以我们将语言包放在项目里,规划项目目录,增加 lang 目录来存放语言对照
新建index.js

import Vue from 'vue'
import VueI18n from 'vue-i18n'
Vue.use(VueI18n)

const i18n = new VueI18n({
  locale: localStorage.getItem('lang') || 'cn',    // 语言标识
  messages: {
    'cn': require('./cn'),   // 中文语言包
    'en': require('./en')    // 英文语言包
  }
})

export default i18n

加载中英双语,然后再分别创建 cn.js和en.js
编写语言对照, 我们按照项目来规划类似main auth nav这样的分组,或者理解为命名空间吧
// cn.js

export const main = {
  'logo': '认证管理后台',
  'searchbox': '快速搜索',
  'profile': '用户中心',
  'password': '修改密码',
  'logout': '退出登陆',
  'lang_cn': '简体中文',
  'lang_en': '英文'
}

export const auth = {
  'login_title': '用户登陆',
  'logout_title': '用户退出',
  'username': '用户名',
  'password': '密码',
  'login': '登陆',
  'relogin': '重新登陆',
  'register': '注册',
  'password_forgot': '忘记密码'
}

export const nav = {
  dashboard: '运行状态',
  dev: '我的设备',
  portal: '认证设置',
  network: '网络管理',
  stat: '统计分析',
  users: '认证用户',
  extends: '扩展功能'
}

修改main.js在项目引入i18n
import i18n from './lang'

...

new Vue({
  el: '#app',
  i18n,
  router,
  template: '<App/>',
  components: { App }
})

在页面html中使用的方式
<div>{{ $t('main.logo') }}</div>
<input type="text" :placeholer="$t('auth.username')" />

在js中使用
data () {
  return {
    login_title: this.$t('auth.login_title')
  }
}

源码下载
精品好课
React实战视频教程仿京东移动端电商
React是前端最火的框架之一,就业薪资很高,本课程教您如何快速学会React并应用到实战,对正在工作当中或打算学习React高薪就业的你来说,那么这门课程便是你手中的葵花宝典。
最新完整React视频教程从入门到精通纯干货纯实战
React是目前最火的前端框架,就业薪资很高,本课程教您如何快速学会React并应用到实战,教你如何解决内存泄漏,常用UI库的使用,自己封装组件,正式上线白屏问题,性能优化等。对正在工作当中或打算学习React高薪就...
VUE2+VUE3视频教程从入门到精通(全网最全的Vue课程)
VUE是目前最火的前端框架之一,就业薪资很高,本课程教您如何快速学会VUE+ES6并应用到实战,教你如何解决内存泄漏,常用UI库的使用,自己封装组件,正式上线白屏问题,性能优化等。对正在工作当中或打算学习VUE高薪就...
jQuery视频教程从入门到精通
jquery视频教程从入门到精通,课程主要包含:jquery选择器、jquery事件、jquery文档操作、动画、Ajax、jquery插件的制作、jquery下拉无限加载插件的制作等等......
HTML5视频播放器video开发教程
适用人群1、有html基础2、有css基础3、有javascript基础课程概述手把手教你如何开发属于自己的HTML5视频播放器,利用mp4转成m3u8格式的视频,并在移动端和PC端进行播放支持m3u8直播格式,兼容...
HTML5基础入门视频教程易学必会
HTML5基础入门视频教程,教学思路清晰,简单易学必会。适合人群:创业者,只要会打字,对互联网编程感兴趣都可以学。课程概述:该课程主要讲解HTML(学习HTML5的必备基础语言)、CSS3、Javascript(学习...
最新完整React+VUE视频教程从入门到精,企业级实战项目
React和VUE是目前最火的前端框架,就业薪资很高,本课程教您如何快速学会React和VUE并应用到实战,教你如何解决内存泄漏,常用库的使用,自己封装组件,正式上线白屏问题,性能优化等。对正在工作当中或打算学习Re...
Vue2+Vue3+ES6+TS+Uni-app开发微信小程序从入门到实战视频教程
2021年最新Vue2+Vue3+ES6+TypeScript和uni-app开发微信小程序从入门到实战视频教程,本课程教你如何快速学会VUE和uni-app并应用到实战,教你如何解决内存泄漏,常用UI库的使用,自己...
收藏
扫一扫关注我们