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