Vue國際化的使用

来源:https://www.cnblogs.com/absolute-child/archive/2018/08/05/9425968.html
-Advertisement-
Play Games

首先是是在main.js文件中把國際化引入進來 1 import Vue from 'vue' 2 import App from './App' 3 import router from './router' 4 import VueI18n from 'vue-i18n' 5 6 Vue.use ...


首先是是在main.js文件中把國際化引入進來

 1 import Vue from 'vue'
 2 import App from './App'
 3 import router from './router'
 4 import VueI18n from 'vue-i18n'
 5 
 6 Vue.use(VueI18n)
 7 Vue.config.productionTip = false
 8 const i18n = new VueI18n({
 9   locale: 'zh-CN',
10   messages: {
11     'zh-CN': {
12       'detail1': '詳情1',
13       'detail2': '詳情2',
14       'detail3': '詳情3',
15       'year': '年'
16     },
17     'en-US': {
18       'detail1': 'Detail1',
19       'detail2': 'Detail2',
20       'detail3': 'Detail3',
21       'year': 'year'
22     }
23   }
24 })
25 
26 new Vue({
27   el: '#app',
28   i18n: i18n,
29   router,
30   components: { App },
31   template: '<App/>'
32 })
main.js

其中我現在先在這個文件裡面簡單配置一些國際化的數據,放到常量i18n中,其中locale就是用來配置當前系統的語言的。目前這裡採用的中文的,如果頁面可以支持多種語言切換的話,這事件觸發後就是改這裡的配置的值,若改成英文,這設置為“en-US”

接下來就是在頁面中使用的問題了。

第一種使用方式:在視圖模板中直接使用,採用{{$t('xxxx')}}的方式。如下我現在使用'detail1'這個的國際化:

頁面顯示的效果就是:

中文效果:

 

英文效果:

 第二種使用方式,是在腳本裡面使用,這時可以採用 this.$t('xxxx')的方式。如下

 1 <template>
 2   <div>
 3       <h1>{{$t('detail1')}}</h1>
 4       <el-button @click="print">列印</el-button>
 5   </div>
 6 </template>
 7 <script>
 8   export default{
 9    methods:{
10        print(){
11            console.log(this.$t('detail1'))
12        }
13    },
14   }
15 </script>
16 
17 <style>
18 
19 </style>
test.vue

因為第二種方式中的this,指的是vue實例,所以這種方式在.vue結尾的的文件中能夠生效。但是如果是例如在我們定義常量的文件裡面要使用的話,就行不通了。那我們在常量中定義的數據,到頁面顯示,要怎樣才能也使用上這個國際化呢。這個我們就來看下第三種方式。

第三種使用方式,在普通js文件中中配置,在頁面上也展示國際化。

首先我們現在main.js文件中的國際化裡面增加月份的國際化配置:

 1 const i18n = new VueI18n({
 2   locale: 'zh-CN',
 3   messages: {
 4     'zh-CN': {
 5       'detail1': '詳情1',
 6       'detail2': '詳情2',
 7       'detail3': '詳情3',
 8       'year': '年',
 9       'month1': '1月',
10       'month2': '2月',
11       'month3': '3月'
12     },
13     'en-US': {
14       'detail1': 'Detail1',
15       'detail2': 'Detail2',
16       'detail3': 'Detail3',
17       'year': 'year',
18       'month1': 'January',
19       'month2': 'February',
20       'month3': 'March'
21     }
22   }
23 })
main.js

然後我們準備一個constant.js文件。在裡面如下配置:

export const months = ['month1', 'month2', 'month3'].map((item, index) => { return {'label': item, 'value': index + 1} })
constants.js

這裡註意的是,我這裡的月份,直接使用的就是我們國際化裡面配置的月份的key值。接下來我們就來頁面上使用了。

這裡把月份放到下拉框裡面展示為例:

 1 <template>
 2   <div>
 3       <h1>{{$t('detail1')}}</h1>
 4       <el-button @click="print">列印</el-button>
 5      <el-select v-model="month" placeholder="請選擇月份">
 6         <el-option v-for="item in months" :key="item.value" :label="$t(item.label)" :value="item.value">
 7         </el-option>
 8       </el-select>
 9   </div>
10 </template>
11 <script>
12 import {months} from '@/util/constants'
13   export default{
14     data(){
15         return{
16             month:'',
17             months:[]
18         }
19       },
20     methods:{
21        print(){
22            console.log(this.$t('detail1'))
23        }
24    },
25    created(){
26        this.months = months
27    }
28   }
29 </script>
30 
31 <style>
32 
33 </style>
test.vue

這裡註意的一點就是,在視圖模型中,下拉框的label採用  :label="$t(item.label)"的方式,從而來到達國際展示的方式。

中文頁面效果如下:

英文頁面效果如下:

 

到此,三種方式介紹完畢。因為在開發中遇到這樣的問題,故順便總結下分享出來。如果大家有其他類似的問題或方式可以留言分享^_^。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JQuery_1_選擇器 什麼是JQuery JQuery實際上就是一個javascript文件,它是一堆由javascript寫好的工具程式,一個被封裝好的js工具庫。它在js基礎之上做了很多的優化,讓網頁腳本的編寫過程更加的便捷高效。 JQuery有很多的版本,但各版本之間的差異都不是太大,基礎 ...
  • Vuex Vuex是專為Vue.js應用程式開發的狀態管理模式。它採用集中式存儲管理應用的所有組件的狀態,並以相應的規則保證狀態以一種可預測的方式發生變化。 應用場景 對於深層嵌套組件,依靠props進行父子組件的傳遞顯得太過臃腫,而且難以維護。而vuex的出現就是為瞭解決數據傳遞的問題。Vuex作 ...
  • 一、什麼是Sass Sass (Syntactically Awesome StyleSheets)是css的一個擴展開發工具,它允許你使用變數、條件語句等,使開發更簡單可維護。這裡是官方文檔。 二、基本語法 1)變數 sass的變數名必須是一個$符號開頭,後面緊跟變數名。 特殊變數:如果變數嵌套在 ...
  • javascript javascript概念 簡稱js,它可以針對網頁上面的元素,讓其動態的產生變化。 javascript的使用範圍 javascript是由瀏覽器來執行的。包含在網頁中被瀏覽器連同html、css一同解析並執行,它的運行必須依附於網頁與瀏覽器,而不能夠直接被執行。 javasc ...
  • JS的閉包,是一個談論得比較多的話題了,不過細細想來,有些人還是理不清閉包的概念定義以及相關的特性。 這裡就整理一些,做個總結。 一、閉包 1. 閉包的概念 閉包與執行上下文、環境、作用域息息相關 執行上下文 執行上下文是用於跟蹤運行時代碼求值的一個規範設備,從邏輯上講,執行上下文是用執行上下文棧( ...
  • CSS的基礎概念 CSS的作用就是對網頁中元素進行更精細的美化 在網頁中加入CSS的三種方法 比如:<p style=”今天天氣一般</p> <style type=”text/css”></style>開始與結束標簽之間的樣式表。 然後:在html網頁中使用: 或 將外部樣式表引入到當前網頁中來。 ...
  • 1. 一個對象以“{”(左括弧)開始,“}”(右括弧)結束。每個“名稱”後跟一個“:”(冒號);“"名稱/值" 對”之間運用 “,”(逗號)分隔。 名稱用引號括起來;值如果是字元串則必須用括弧,數值型則不須要。例如:var json = { "name": "姓名", "sex": "25" };2 ...
  • HTML基礎 一、 <font></font>字體 通常在網頁中我們儘量使用宋體,黑體,微軟雅黑(win7以上)這些字體。因為這些字體通常是操作系統自帶的。如果我們使用了電腦上不存在的字體,那麼電腦將使用預設字體,一般是宋體。 二、 color屬性(十六進位數值表示123456789abcdef ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...