vue3 vue-i18n 國際化

1、安裝

$ npm i vue-i18n

2恕刘、配置

1、創(chuàng)建 utils/i18n.js
2、編輯 utils/i18n.js

// i18n.js
import {
    createI18n
} from 'vue-i18n';

const messages = {
    cn: {
        country: '中文',
        common: {
            login: '登錄',
            toVip: '升級VIP'
        },
        loginPage: {
            mobile: '手機短信',
            wechatLogin: '使用微信掃一掃登錄',
            privacyPolicy: '隱私政策'
        }
    },
    en: {
        country: 'English',
        common: {},
        loginPage: {}
    },
    tc: {
        country: '中文繁體',
    },
    mys: {
        country: 'Bahasa Melayu',
    },
    sa: {
        country: '???????',
    }
};

const i18n = createI18n({
    locale: 'cn', // set default locale
    fallbackLocale: 'en',
    messages, // set locale messages
});

export default {
    i18n, // vue綁定用
    messages // 手動選擇國際化需要使用
};

3矮湘、引入

  • main.js
import i18nObj from './utils/i18n.js';

const app = createApp(App);
app.use(i18nObj.i18n);
  • yourComponent.vue 國際化手動選擇代碼
// setup
import i18nObj from '../utils/i18n.js'

const Countries = reactive([]) // 語種列表,用來下拉讓用戶選擇
const currCountry = ref('中文')

// 初始化語種口糕、并緩存
for (let c in i18nObj.messages) {
    Countries.push(c)
    if (!localStorage.getItem('country')) {
        localStorage.setItem('country', '中文')
    } else {
        currCountry.value = localStorage.getItem('country')
    }
}

function changeLocale(newLocale) {
    locale.value = newLocale;
}

function commandClick(key) {
    changeLocale(key)
    currCountry.value = i18nObj.messages[key].country
    localStorage.setItem('country', i18nObj.messages[key].country)
}
<el-dropdown @command="commandClick" size="small" type="primary">
  <el-text>{{ currCountry }}</el-text>
  <template #dropdown>
    <el-dropdown-menu>
      <el-dropdown-item v-for="c in Countries" :key="c" :command="c">
        {{ i18nObj.messages[c].country }}
      </el-dropdown-item>
    </el-dropdown-menu>
  </template>
</el-dropdown>

4缅阳、 yourComponent.vue 國際化引入數(shù)據

<div>{{ $t('cuntry') }}<div>
<div>{{ $t('loginPage.mobile') }}<div>

如果值為數(shù)組,不拿直接訪問數(shù)組,需要依次取出下標

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末十办,一起剝皮案震驚了整個濱河市秀撇,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌向族,老刑警劉巖呵燕,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異件相,居然都是意外死亡再扭,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進店門夜矗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來泛范,“玉大人,你說我怎么就攤上這事紊撕“盏矗” “怎么了?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵对扶,是天一觀的道長区赵。 經常有香客問我,道長辩稽,這世上最難降的妖魔是什么惧笛? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮逞泄,結果婚禮上患整,老公的妹妹穿的比我還像新娘。我一直安慰自己喷众,他們只是感情好各谚,可當我...
    茶點故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著到千,像睡著了一般昌渤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上憔四,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天膀息,我揣著相機與錄音,去河邊找鬼了赵。 笑死潜支,一個胖子當著我的面吹牛,可吹牛的內容都是我干的柿汛。 我是一名探鬼主播冗酿,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了裁替?” 一聲冷哼從身側響起项玛,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎弱判,沒想到半個月后襟沮,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡裕循,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年臣嚣,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片剥哑。...
    茶點故事閱讀 39,764評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡硅则,死狀恐怖,靈堂內的尸體忽然破棺而出株婴,到底是詐尸還是另有隱情怎虫,我是刑警寧澤,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布困介,位于F島的核電站大审,受9級特大地震影響,放射性物質發(fā)生泄漏座哩。R本人自食惡果不足惜徒扶,卻給世界環(huán)境...
    茶點故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望根穷。 院中可真熱鬧姜骡,春花似錦、人聲如沸屿良。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽尘惧。三九已至康栈,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間喷橙,已是汗流浹背啥么。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留贰逾,地道東北人饥臂。 一個月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像似踱,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,665評論 2 354

推薦閱讀更多精彩內容