使用vue國際化中出現內置的組件沒法切換語言的問題(element-ui、ivew)

在main.js中引入對應組件的語言包
eg:
  vue

 1     import VueI18n from 'vue-i18n'; // 引入國際化
 2     import elementEn from 'element-ui/lib/locale/lang/en'; // element-ui 英語語言包
 3     import elementZh from 'element-ui/lib/locale/lang/zh-CN'; // element-ui 中文語言包
 4 
 5   import ivewZh from 'iview/dist/locale/zh-CN'; // ivew 中文語言包
 6   import ivewEn from 'iview/dist/locale/en-US'; // ivew 英文語言包
 7 
 8   import zh from './i18n/lang/zh'; // 本身的中文語言包
 9   import en from './i18n/lang/en'; // 本身的英文語言包
10   // 這是主要沒改變的問題所在
11   Vue.use(iView, {
12     i18n: (key, value) => i18n.t(key, value)
13   });
14   Vue.use(ElementUI, {
15     i18n: (key, value) => i18n.t(key, value)
16   });
17   Vue.use(VueI18n);
18 
19   //語言國際化
20   const messages = {
21   'zh': {
22     ...zh,
23     ...elementZh,
24     ...ivewZh
25   }, // 中文語言包
26   'en': {
27     ...en,
28     ...elementEn,
29     ...ivewEn
30   } //英文語言包
31  };
32 // 經過cookie存儲
33 export function getLanguage() {
34   const chooseLanguage = Cookies.get('language');
35   if (chooseLanguage) return chooseLanguage;
36 
37     const language = (navigator.language || navigator.browserLanguage).toLowerCase();
38     const locales = Object.keys(messages);
39     for (const locale of locales) {
40       if (language.indexOf(locale) > -1) {
41         return locale;
42       }
43     }
44     return 'en';
45   }
46 
47   const i18n = new VueI18n({
48     locale: getLanguage(), // 語言標識
49     messages
50   })
51 
52   new Vue({
53     el: '#app',
54     i18n
55   })
相關文章
相關標籤/搜索