vue實踐---vue不依賴外部資源實現(xiàn)簡單多語操作
vue使用多語,最常見的就是 vue-i18n, 但是如果開發(fā)中的多語很少,比如就不到10個多語,這樣就沒必要引入vue-i18n了, 引入了反正導致代碼體積大了,這時候單純用vue實現(xiàn)多語就是比較好的選擇。
第一步
首先建立一個locales.js 存放多語語言包的內容,這里只寫了 zh-CN, en這兩種語言,其他還想新增的話 方法一樣,代碼如下:
export default {
'zh-CN': {
name: '我是中文名字'
},
'en': {
name: 'I am English name'
}
}
第二步
通過瀏覽器的語言環(huán)境,獲取對應的語言包,并吧語言包值付給 data 中的 locales
data () {
return {
locales: (() => {
// this.lang是父組件傳遞過來的, 這里的意思就是lang 優(yōu)先使用父組件傳遞的語言,如果沒有傳遞,就使用瀏覽器的語言(navigator.language)
const lang = this.lang || navigator.language
let useLang = /^zh/.test(lang) ? 'zh-CN' : /^en/.test(lang) ? 'en' : lang
// Object.keys 獲取可枚舉的屬性 如果瀏覽器的語言不是英語 中文, 而且傳遞的lang參數也不是這兩種之一,就默認使用 zh-CN
if (!Object.keys(locales).includes(useLang)) useLang = 'zh-CN'
return locales[useLang]
})(),
}
},
這個locales最終返回的是一個對象,比如,如果是中文環(huán)境,返回的數據如下:
{
name: '我是中文名字'
}
第三步
既然語言包都獲取到了,還剩一個從語言包里面 獲取對應key的方法:
methods: {
$_t (key) {
// this.locales就是上面那個對象
let localeStr = this.locales[key]
return localeStr
}
}
通過$_t這個方法,傳入key,就可以獲取到對應的value
總結&優(yōu)化:
這樣就實現(xiàn)了不用依賴vue-i18n這樣的外部依賴,只使用vue就實現(xiàn)了多語;
$_t 這個方法可以放到 mixins 里面就避免了每次都要引入這個方法。
具體代碼看這里: https://github.com/YalongYan/vue-practice/tree/master/vue-simple-multilingual
補充知識:vue-cli 打包(npm run build) 出現(xiàn) ERROR in xx..js from UglifyJs Unexpected token: punc (()
之前打包還沒問題,這次就報錯了,后來發(fā)現(xiàn)原來是少了 .babelrc 文件, 網上找了好多方法都不行,后來看了之前的項目,原來是少了 .babelrc 文件, 只要在根目錄下建立這個文件, 文件內容如下:
{
"presets": [
["env", { "modules": false }],
"stage-3"
]
}
文件位置看下圖:

以上這篇vue實踐---vue不依賴外部資源實現(xiàn)簡單多語操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
在導入.vue文件的時候,ts報錯提示:找不到模塊“@/Layout/index.vue”或其相應的類型聲明問題
這篇文章主要介紹了在導入.vue文件的時候,ts報錯提示:找不到模塊“@/Layout/index.vue”或其相應的類型聲明問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
Vue3使用transition組件改變DOM屬性的方式小結
這篇文章主要為大家詳細介紹了Vue3中使用transition組件改變DOM屬性的常用方式,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2024-01-01
vue如何解決el-select下拉框顯示ID不顯示label問題
這篇文章主要介紹了vue如何解決el-select下拉框顯示ID不顯示label問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06

