vue項(xiàng)目配置國(guó)際化$t('')的介紹和用法示例
前言
vue 項(xiàng)目中 $t('')直接在html中直接調(diào)用這個(gè)函數(shù) {{ $t('login.title') }}
$t是引入國(guó)際化后,掛到了Vue.prototype上的一個(gè)方法,接受一個(gè)字符串作為參數(shù)
<div class="title-container"> ? ? ?<h3 class="title"> ? ? ? ? ?{{ $t('login.title') }} ? ? ?</h3> </div> //---------$t('login.title') 我理解的意思是去當(dāng)前語(yǔ)言環(huán)境下login對(duì)象的title值
1.main.js中引入vue-i18n
// 國(guó)際化 這個(gè)文件是本地創(chuàng)建的 主要是獲取當(dāng)前語(yǔ)言環(huán)境和相應(yīng)的變量值 import i18n from './lang' new Vue({ ? ? el: '#app',? ? ? ? i18n, ? ? render: h => h(App) })
2.瀏覽器的語(yǔ)言環(huán)境不同,相應(yīng)設(shè)置不同的語(yǔ)言配置文件
// ./lang/index.js import Vue from 'vue' //引入vue import VueI18n from 'vue-i18n' //引入vue的國(guó)際化插件 import Cookies from 'js-cookie' //我這里需要,所以引入輕量級(jí)的處理cookies的js import elementZhLocale from 'element-ui/lib/locale/lang/zh-CN'// element-ui lang import elementEnLocale from 'element-ui/lib/locale/lang/en' // element-ui lang import zhLocale from './zh' //本地創(chuàng)建的中文環(huán)境配置文件 import enLocale from './en' //本地創(chuàng)建的英文環(huán)境配置文件 Vue.use(VueI18n) // 通過(guò)插件的形式掛載,通過(guò)全局方法?Vue.use()?使用插件 const messages = { en: { ? ? ? ? ...enLocale, ? ? ? ? ...elementEnLocale ? ? }, ? ? zh: { ? ? ? ? ...zhLocale, ? ? ? ? ...elementZhLocale ? ? } } //獲取當(dāng)前語(yǔ)言環(huán)境,通過(guò)后臺(tái)返回的語(yǔ)言或者瀏覽器語(yǔ)言環(huán)境 export function getLanguage() { ? ? const chooseLanguage = Cookies.get('language')//取后臺(tái)設(shè)置的語(yǔ)言 ? ? if (chooseLanguage) return chooseLanguage //如果后臺(tái)沒(méi)有返回語(yǔ)言則根據(jù)瀏覽器的語(yǔ)言環(huán)境返回語(yǔ)言變量 ? ? const language = (navigator.language || navigator.browserLanguage).toLowerCase() ? ? const locales = Object.keys(messages)//獲取前端設(shè)置的所有語(yǔ)言 //遍歷所有語(yǔ)言值組成的數(shù)組,匹配前端設(shè)置的語(yǔ)言能匹配到就返回改語(yǔ)言值 ? ? for (const locale of locales) { ? ? ? ? if (language.indexOf(locale) > -1) { ? ? ? ? ? ? return locale ? ? ? ? } ? ? } //如果都沒(méi)匹配到就直接返回英文 ? ? return 'en' } const i18n = new VueI18n({ //語(yǔ)言標(biāo)識(shí) this.$i18n.locale 通過(guò)切換locale的值來(lái)實(shí)現(xiàn)語(yǔ)言切換 //如:this.$i18n.locale='en' 直接切換成英文,僅限于配置了語(yǔ)言的一些變量 ? ? locale: getLanguage(),//調(diào)的上邊這個(gè)函數(shù) ? ? messages //上邊配置的語(yǔ)言標(biāo)識(shí)對(duì)應(yīng)的不同配置 }) export default i18n
3.創(chuàng)建不同語(yǔ)言標(biāo)識(shí)對(duì)應(yīng)的文件,以中文環(huán)境為例
// ./lang/index.js 創(chuàng)建文件 存儲(chǔ)語(yǔ)言對(duì)應(yīng)的一些變量 export default {? ? login: { ? ? ? ? title: '登錄表單', ? ? }, ? ? warning: '警告信息' }
總結(jié)
到此這篇關(guān)于vue項(xiàng)目配置國(guó)際化 $t('')的介紹和用法的文章就介紹到這了,更多相關(guān)vue配置國(guó)際化 $t('')內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue?Echarts實(shí)現(xiàn)儀表盤(pán)案例
這篇文章主要為大家詳細(xì)介紹了vue?Echarts實(shí)現(xiàn)儀表盤(pán)案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03vue3如何解決各場(chǎng)景l(fā)oading過(guò)度(避免白屏尷尬!)
在開(kāi)發(fā)的過(guò)程中點(diǎn)擊提交按鈕,或者是一些其它場(chǎng)景總會(huì)遇到loading加載,下面這篇文章主要給大家介紹了關(guān)于vue3如何解決各場(chǎng)景l(fā)oading過(guò)度的相關(guān)資料,避免白屏尷尬,需要的朋友可以參考下2023-03-03Vue中使用vue-plugin-hiprint插件進(jìn)行打印的功能實(shí)現(xiàn)
hiprint 是一個(gè)web 打印的js組件,無(wú)需安裝軟件,支持windows,macOS,linux 系統(tǒng),支持移動(dòng)端,PC端瀏覽器,angular,vue,react 等 分頁(yè)預(yù)覽,打印,操作簡(jiǎn)單,運(yùn)行快速,本文介紹了Vue中使用vue-plugin-hiprint插件進(jìn)行打印,需要的朋友可以參考下2025-04-04在Vue3中使用event?bus(事件總線(xiàn))的步驟詳解
在Vue?3中,可以通過(guò)創(chuàng)建一個(gè)事件總線(xiàn)(event?bus)來(lái)實(shí)現(xiàn)組件之間的通信,要在Vue?3中使用事件總線(xiàn),主要步驟有:1、創(chuàng)建一個(gè)新的Vue實(shí)例作為事件總線(xiàn),2、在組件中引入并使用該事件總線(xiàn),以下是詳細(xì)的步驟和示例,需要的朋友可以參考下2025-01-01