1. // 按需引入 Element
  2. import Vue from 'vue'
  3. import { Button, Select } from 'element-ui'
  4. import lang from 'element-ui/lib/locale/lang/en'
  5. import locale from 'element-ui/lib/locale'
  6. // 设置语言
  7. locale.use(lang)
  8. // 引入组件
  9. Vue.component(Button.name, Button)
  10. Vue.component(Select.name, Select)

如果使用其它语言,默认情况下中文语言包依旧是被引入的,可以使用 webpack 的 NormalModuleReplacementPlugin 替换默认语言包。

  1. {
  2. plugins: [
  3. new webpack.NormalModuleReplacementPlugin(/element-ui[\/\\]lib[\/\\]locale[\/\\]lang[\/\\]zh-CN/, 'element-ui/lib/locale/lang/en')
  4. ]
  5. }

兼容 vue-i18n@5.x

Element 兼容 vue-i18n@5.x,搭配使用能更方便地实现多语言切换。

如果不使用 vue-i18n@5.x,而是用其他的 i18n 插件,Element 将无法兼容,但是可以自定义 Element 的 i18n 的处理方法。

  1. import Vue from 'vue'
  2. import Element from 'element-ui'
  3. import enLocale from 'element-ui/lib/locale/lang/en'
  4. import zhLocale from 'element-ui/lib/locale/lang/zh-CN'
  5. i18n: function (path, options) {
  6. // ...
  7. }
  8. })

兼容 vue-i18n@6.x

  1. import Vue from 'vue'
  2. import Element from 'element-ui'
  3. import VueI18n from 'vue-i18n'
  4. import enLocale from 'element-ui/lib/locale/lang/en'
  5. import zhLocale from 'element-ui/lib/locale/lang/zh-CN'
  6. Vue.use(VueI18n)
  7. const messages = {
  8. en: {
  9. ...enLocale // 或者用 Object.assign({ message: 'hello' }, enLocale)
  10. },
  11. zh: {
  12. message: '你好',
  13. ...zhLocale // 或者用 Object.assign({ message: '你好' }, zhLocale)
  14. }
  15. }
  16. // Create VueI18n instance with options
  17. locale: 'en', // set locale
  18. messages, // set locale messages
  19. })
  20. Vue.use(Element, {
  21. i18n: (key, value) => i18n.t(key, value)
  22. })
  23. new Vue({ i18n }).$mount('#app')

通过 CDN 的方式加载语言文件

  1. <script src="//unpkg.com/vue"></script>
  2. <script src="//unpkg.com/element-ui"></script>
  3. <script src="//unpkg.com/element-ui/lib/umd/locale/en.js"></script>
  4. <script>
  5. ELEMENT.locale(ELEMENT.lang.en)
  6. </script>

搭配 vue-i18n 使用

  1. <script src="//unpkg.com/vue"></script>
  2. <script src="//unpkg.com/vue-i18n/dist/vue-i18n.js"></script>
  3. <script src="//unpkg.com/element-ui"></script>
  4. <script src="//unpkg.com/element-ui/lib/umd/locale/zh-CN.js"></script>
  5. <script src="//unpkg.com/element-ui/lib/umd/locale/en.js"></script>
  6. <script>
  7. Vue.locale('en', ELEMENT.lang.en)
  8. </script>

目前 Element 内置了以下语言:

  • 简体中文(zh-CN)
  • 英语(en)
  • 德语(de)
  • 葡萄牙语(pt)
  • 西班牙语(es)
  • 丹麦语(da)
  • 法语(fr)
  • 繁体中文(zh-TW)
  • 意大利语(it)
  • 韩语(ko)
  • 日语(ja)
  • 荷兰语(nl)
  • 越南语(vi)
  • 俄语(ru-RU)
  • 土耳其语(tr-TR)
  • 巴西葡萄牙语(pt-br)
  • 波斯语(fa)
  • 泰语(th)
  • 印尼语(id)
  • 保加利亚语(bg)
  • 波兰语(pl)
  • 芬兰语(fi)
  • 瑞典语(sv-SE)
  • 希腊语(el)
  • 斯洛伐克语(sk)
  • 加泰罗尼亚语(ca)
  • 捷克语(cs-CZ)
  • 乌克兰语(ua)
  • 土库曼语(tk)
  • 泰米尔语(ta)
  • 拉脱维亚语(lv)
  • 南非荷兰语(af-ZA)
  • 爱沙尼亚语(ee)
  • 斯洛文尼亚语(sl)
  • 阿拉伯语(ar)
  • 希伯来语(he)
  • 立陶宛语(lt)
  • 蒙古语(mn)
  • 哈萨克斯坦语(kz)
  • 匈牙利语(hu)
  • 罗马尼亚语(ro)
  • 库尔德语(ku)
  • 维吾尔语(ug-CN)
  • 高棉语(km)
  • 塞尔维亚语(sr)
  • 巴斯克语(eu)
  • 吉尔吉斯语(kg)
  • 亚美尼亚语 (hy)
  • 克罗地亚 (hr)