在Vue.js中設置中文是非常簡單的。無論是在模板中實現國際化,還是在組件中使用中文文字,均可通過Vue自帶的i18n插件輕松實現。
首先需要在Vue項目根目錄下的package.json文件中加入以下語言包:
{
"dependencies": {
...
"vue-i18n": "^8.18.1"
...
}
}
接著,我們需要在Vue實例中進行i18n插件的初始化及配置。打開main.js文件,引入Vue-i18n依賴,實例化出i18n對象。如下:
import VueI18n from 'vue-i18n'
Vue.use(VueI18n)
const i18n = new VueI18n({
locale: 'zh-CN', // 可以設置默認語言環境
messages: {
'zh-CN': { // 中文語言包
home: '首頁',
about: '關于我們',
...
},
'en-US': { // 英文語言包
home: 'Home',
about: 'About Us',
...
}
}
})
i18n對象中的locale指定了當前使用的語言環境,默認值為'zh-CN'(中文簡體),messages對象是一個包含多個語言環境的對象,其中每種語言環境都有一份對應的語言包,即一個鍵值對。鍵是語言環境,值是一個對象,包含了需要翻譯的文本字符串。我們可以根據需要添加新的語言包。
為了方便,我們可以將i18n對象定義在Vue實例的data屬性中,這樣我們在任何地方都可以輕松獲取和修改當前的語言環境。例如:
export default new Vue({
el: '#app',
data: {
i18n // 將i18n對象注入到當前Vue實例中
},
render: h =>h(App)
})
最后,在需要翻譯的地方使用Vue的內置指令{{ $t(key) }}即可。其中,$t()函數參數是一個字符串,表示需要翻譯的文本在語言包中的鍵值。例如在Vue組件中:
<template><div><h1>{{ $t('home') }}</h1>// 翻譯首頁
<p>{{ $t('about') }}</p>// 翻譯關于我們頁面
</div></template><script>export default {
data() {
return {
...
}
},
...
}
</script>
這樣,我們就可以通過i18n插件輕松地實現Vue中的國際化。而且,i18n還可以支持動態更新語言環境,具備多語種格式化、選擇性翻譯等更高級的特性。
上一篇html愛心代碼中間有字
下一篇vue怎么設置模式