vue實現(xiàn)多語言切換(i18next-i18next-scanner)

實現(xiàn)思路

1,i18next? 多語言轉(zhuǎn)換插件

2棍苹,i18next-scanner 自動掃描代碼中的中文

3咬扇,中文作為多語言的key,通過crc32轉(zhuǎn)為語音包的key


第一步:準備好各種包(插件)

1. npm install crc -S

2. npm install vue-i18n -S

3. npm install?i18next-scanner -D

下載完之后廊勃,開始創(chuàng)建配置文件懈贺,首先在package.json?同級目錄下?創(chuàng)建js文件;i18next-scaner.config.js
js配置如下:

const fs = require('fs')// node自帶 fs文件轉(zhuǎn)換

const { crc32 } = require('crc')// 事先下載 npm install crc 類似哈希的轉(zhuǎn)換格式

module.exports = {

input: [

'src/**/*.{js,vue}',

? ? // Use ! to filter out files or directories

? ? '!src/config/i18n/**',

? ? '!**/node_modules/**'

? ],

? output:'./', // 輸出目錄

? options: {

debug:true,

? ? func:false,

? ? trans:false,

? ? lngs: ['en', 'cn', 'dn'],

? ? defaultLng:'cn',

? ? resource: {

loadPath:'./src/config/i18n/{{lng}}/{{ns}}.json', // 輸入路徑

? ? ? savePath:'./src/config/i18n/{{lng}}/{{ns}}.json', // 輸出路徑

? ? ? jsonIndent:2,

? ? ? lineEnding:'\n'

? ? },

? ? removeUnusedKeys:false, // 移除未使用的key

? ? nsSeparator:false, // namespace separator

? ? keySeparator:false, // key separator

? ? interpolation: {

prefix:'{{',

? ? ? suffix:'}}'

? ? }

},

? transform:function customTransform(file, enc, done) {// 自己通過該函數(shù)來加工key或value

? ? 'use strict'

? ? const parser =this.parser

const content = fs.readFileSync(file.path, enc)

/**

? ? * @param {list} array 指定掃描的標識

? ? */

? ? parser.parseFuncFromString(content, {list: ['lang'] }, (key, options) => {

options.defaultValue = key

// 將傳入的文字轉(zhuǎn)成配置的 key坡垫,不一定非用 crc梭灿,別的也行,如果內(nèi)容不會影響 json 格式冰悠,不用也行

? ? ? let hashKey =`k${crc32(key).toString(16)}`

? ? ? parser.set(hashKey, options)

})

done()

}

}

上個圖:

-------i18next-scaner.config.js配置完成--------
第二步堡妒,src目錄下新建config文件夾,config文件夾內(nèi)新建i18n文件夾溉卓,i18n文件夾內(nèi)新建index.js文件皮迟,同時另外新建en文件夾,cn文件夾桑寨,如下圖:

此時還不能進行npm run scan掃描翻譯伏尼,還需要對 i18n里面的index.js配置如下:

import Vuefrom 'vue'

import VueI18nfrom 'vue-i18n'

import enfrom './en/translation.json'

import cnfrom './cn/translation.json'

import crc32from 'crc/crc32'

/* 語言包導(dǎo)入*/

Vue.use(VueI18n)

const i18n =new VueI18n({

?locale:'cn', // set locale 默認情況下是中文,使用cn文件下的語言

? messages: { en, cn }

})

export function lang(key) {

let hashKey =`k${crc32(key).toString(16)}`

? let words = i18n.t(hashKey)

if (words === hashKey) {

words = key

console.log(key, '-沒翻譯')

}

return words

}

export default i18n

-----------------index.js配置完成------------------------

上個圖吧

第三步尉尾;都配置好了之后就開始在main.js進行引入對應(yīng)的文件爆阶,如下圖

第四步:main.js引入對應(yīng)文件之后,在package.json里面的scripts對象里面配置"scan":"i18next-scanner",如圖:


配置好了就可以在控制臺實現(xiàn)自動掃描(只會掃描頁面有攜帶標識的文字,比如{{ $lang('這是一個需要掃描轉(zhuǎn)換的文字') }} )辨图,掃描出來的文字會攜帶對應(yīng)唯一的code值班套。掃描前提是頁面的中文有添加標識,這樣掃描工具才知道哪些文字需要翻譯吱韭。直接上圖:


最頭疼就是如果頁面超級多杉女,需要每個頁面添加翻譯lang標識,賊煩速勇,這是一個手工活,好雞累养匈!不過至少能實現(xiàn)功能? 豁出去了都伪,一個個頁面加吧!加漏了后續(xù)再繼續(xù)加b省!J簟:侄!

最后一步::如何切換語言雅镊,頁面給個按鈕 點擊直接調(diào)用this.$i18n.local = ‘en’ 切換成英文(其他)語言刃滓,根據(jù)自己想要的邏輯隨意切換,這里就不多說了晃危。有什么不明白或有錯漏的 歡迎留言,指正震叮。(這是本人親自做過兩個項目并已經(jīng)成功上線鳍鸵!切換語言是純前端頁面切換,如果后臺也需要翻譯击罪,后續(xù)可根據(jù)后臺返回來的語言贪薪,前端進行同步即可!)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末竣稽,一起剝皮案震驚了整個濱河市霍弹,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌岛宦,老刑警劉巖耍缴,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異债沮,居然都是意外死亡本鸣,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進店門闷煤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鲤拿,“玉大人署咽,你說我怎么就攤上這事生音≈仙” “怎么了?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵域醇,是天一觀的道長蓉媳。 經(jīng)常有香客問我,道長减宣,這世上最難降的妖魔是什么玩荠? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任姨蟋,我火速辦了婚禮眼溶,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘堂飞。我一直安慰自己绑咱,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布铝噩。 她就那樣靜靜地躺著骏庸,像睡著了一般年叮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上只损,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天,我揣著相機與錄音艾栋,去河邊找鬼衬横。 笑死,一個胖子當(dāng)著我的面吹牛蜂林,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播矮锈,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼苞笨,長吁一口氣:“原來是場噩夢啊……” “哼子眶!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起臭杰,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤渴杆,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后囊拜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體比搭,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年蔽莱,在試婚紗的時候發(fā)現(xiàn)自己被綠了盗冷。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片同廉。...
    茶點故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡柑司,死狀恐怖锅劝,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情玻粪,我是刑警寧澤诬垂,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站很洋,受9級特大地震影響隧枫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜官脓,卻給世界環(huán)境...
    茶點故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一卑笨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧湾趾,春花似錦派草、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至瑰步,卻和暖如春璧眠,著一層夾襖步出監(jiān)牢的瞬間读虏,已是汗流浹背袁滥。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留揩徊,地道東北人嵌赠。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像猾普,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子偎窘,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,884評論 2 354

推薦閱讀更多精彩內(nèi)容