Vue项目如何实现国际化?分享一下基于vue-i18n实现国际化的经验

vue项目如何实现国际化?分享一下基于vue-i18n实现国际化的经验

demo源码链接:https://github.com/XieTongXue/how-to/tree/master/vue-internationalization

步骤一:安装vue-i18n

npm install vue-i18n --save

步骤二:main.js文件的配置,在main.js中添加以下跟vue-i18n的使用有关的配置项

// 引入i18n国际化插件
import VueI18n from 'vue-i18n'
Vue.use(VueI18n)

// 注册i18n实例并引入语言文件,文件格式等下解析
const i18n = new VueI18n({
  locale: 'zh',
  messages: {
    'zh': require('@/assets/languages/zh.json'),
    'en': require('@/assets/languages/en.json')
  }
})
//将i18n注入到vue实例中
new Vue({
  el: '#app',
  router,
  store,
  i18n,
  components: { App },
  template: ''
})

 

两个语言文件(zh.json,en.json)源码如下:

 

en.json:

 

{
    "common": {
        "home": "Home",
        "login": "Login",
        "register": "Register",
        "appDownload": "APP Download",
        "aboutUs": "About Us",
        "faq": "FAQ",
        "contact": "Contact Us",
        "join": "Join Us",
        "copyright": "Copyright © ZLGMcu Ltd",
        "news": "News",
        "toggle": "Toggle",
        "welcome": "Welcome, ",
        "userinfo": "Userinfo",
        "firstPage": "Home",
        "setting": "Setting",
        "exit": "Exit"
    },
    "message": {
        "hint1": "Please Input Nickname",
        "hint2": "Please Input Username",
        "hint3": "Please Input Password",
        "hint4": "Don't find picture",
        "hint5": "No Account?",
        "hint6": "Register Now",
        "hint7": "Remember me",
        "hint8": "Can't login in?",
        "placeHolder1": "Nickname",
        "placeHolder2": "Username or Phone Number or Email",
        "placeHolder3": "Password(8 Digits at Least)"
    }
}


zh.json:

 

 

{
    "common":{
        "home": "首页",
        "login": "登录",
        "register": "注册",
        "appDownload": "APP下载",
        "aboutUs": "关于我们",
        "faq": "常见问题",
        "contact": "联系方式",
        "join": "加入我们",
        "copyright": "版权说明 © 广州xxx有限公司",
        "news": "消息",
        "toggle": "切换",
        "welcome": "欢迎您,",
        "userinfo": "个人信息",
        "firstPage":  "主页",
        "setting": "设置",
        "exit": "退出"
    },
    "message":{
        "hint1": "请输入昵称",
        "hint2": "请输入账号",
        "hint3": "请输入密码",
        "hint4": "没有找到",
        "hin5": "没有账号?",
        "hint6": "马上注册",
        "hint7": "记住我",
        "hint8": "登录遇到问题?",
        "placeHolder1": "昵称",
        "placeHolder2": "用户名、手机号或邮箱",
        "placeHolder3": "密码(至少8位字符)"
    }
}


步骤三:使用vue-i18n,请只留意划线或框框部分

 

Vue项目如何实现国际化?分享一下基于vue-i18n实现国际化的经验_第1张图片

代码中的common.welcome对应语言文件中对应的项,各个不同的项引用方式一样,因此不全部展示,点击切换语言触发changeLanguage()方法,改变i18n实例中locale的值,进而实现语言的切换。此文章只展示了英文中文两种语言,其实多语言也一样,只要多写几个语言文件,然后在main.js中进行对应的配置就行。

由于main.js中设置了默认显示zh即中文,所以没有点击切换语言按钮前的效果为:

Vue项目如何实现国际化?分享一下基于vue-i18n实现国际化的经验_第2张图片

点击切换语言后的效果为:

Vue项目如何实现国际化?分享一下基于vue-i18n实现国际化的经验_第3张图片

假如在js中需要国际化,可写成以下形式,举个data中的值国际化的例子:

computed: {
   type () {
     return this.$t('xxx.xxx.xxx')
  }
}

或者: 
 data () {
    return {
        msg: '默认文字'
    }
}

methods: {
    changeLanguage () {
       // 同上,以下多加一行
       this.msg = this.$t('xxx.xxx.xxx')
    }
}

demo:https://github.com/XieTongXue/how-to/tree/master/vue-internationalization

国际化的实现方式有很多,有想到其他方法的欢迎分享;本文的只是其中一种,觉得有不足的地方欢迎指出。

 

你可能感兴趣的:(Vue,前端解决方案)