vue 國際化i18n 多語言切換

来源:https://www.cnblogs.com/huangenai/archive/2018/10/10/9766932.html
-Advertisement-
Play Games

安裝 新建一個文件夾 i18n ,內新建 en.js zh.js index.js 三個文件 準備翻譯信息 en.js zh.js index.js 創建Vue-i18n實例 i18n 掛載到 vue 根實例 main.js 簡單的使用 about.vue 註意: 比如說上面的hi 你要通過這種形式 ...


安裝

npm install vue-i18n

新建一個文件夾 i18n ,內新建 en.js zh.js index.js 三個文件

準備翻譯信息

en.js

export default {
  home: {
    helloworld: "hello workd !"
  }
};

zh.js

export default {
  home: {
    helloworld: "你好世界"
  }
};

index.js

創建Vue-i18n實例

import Vue from "vue";
import VueI18n from "vue-i18n";
import enLocale from "./en";
import zhLocale from "./zh";

Vue.use(VueI18n);
const i18n = new VueI18n({
  locale: localStorage.lang || "zh",
  messages: {
    en: {
      ...enLocale
    },
    zh: {
      ...zhLocale
    }
  }
});
export default i18n;

i18n 掛載到 vue 根實例

main.js

import Vue from "vue";
import App from "./App.vue";
import router from "./router";
import store from "./store";
import i18n from "./assets/i18n/index";

Vue.config.productionTip = false;

Vue.prototype.$i18n = i18n;

new Vue({
  router,
  store,
  i18n,
  render: h => h(App)
}).$mount("#app");

簡單的使用

about.vue

<template>
  <div class="about">
    <h1>{{ $t("home.helloworld") }}</h1>
    <button @click="changeLang()">切換英文</button>
    <p>{{hi}}</p>
  </div>
</template>

<script>
export default {
  data: function() {
    return {};
  },
  computed: {
    hi() {
      return this.$t("home.helloworld");
    }
  },
  methods: {
    changeLang() {
      this.$i18n.locale = "en";
    }
  }
};
</script>

註意:

比如說上面的hi 你要通過這種形式來寫的時候,不能放在data 裡面,因為當語言切換的時候 他是不會變的 ,要寫在computed內

 

此隨筆乃本人學習工作記錄,如有疑問歡迎在下麵評論,轉載請標明出處。

如果對您有幫助請動動滑鼠右下方給我來個贊,您的支持是我最大的動力。


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

-Advertisement-
Play Games
更多相關文章
  • 思路分析:有3種情況 第一種情況,當前頁面curPage < 4 第二種情況,當前頁面curPage == 4 第三種情況,當前頁面curPage>4 此外,還要考慮,當前頁碼 curPage < pageTotal(總頁碼)-2,才顯示 ... 首先,先是前端的佈局樣式 <!-- 後面會在JS中動 ...
  • 兩種居中的方式: Margin:0 auto;和text-align:center; Margin的居中是對自身,text-align對元素內部的文本來說。 隱藏的兩種方式: visibility:hidden;和display:none; visibility 隱藏了還占用著空間,display隱 ...
  • 需要瞭解的知識點: 1. 向指定元素添加事件的方法:addEventListener()方法 2. Dom2級事件中事件流的三個階段:事件捕獲階段、目標元素、事件冒泡階段 3. javascript中 “this與e.target”的區別 addEventListener()方法 語法:addEve ...
  • 1.setTimeout與setInterval的區別 setTimeout: 1.直接使用的話,按照指定 的時間,只執行一次傳入的函數參數。 2.函數的終止使用clearTimeout。 setInterval: 1.直接使用的話,按照指定的時間,迴圈執行傳入的函數參數 2.函數的終止使用clea ...
  • 使用HTML5 canvas的註意事項,非零環繞原則的使用,closePath與lineTo的區別,使用arc產生的問題 ...
  • Sass 快速入門 | SASS 中文網 文檔鏈接:https://www.sasscss.com/getting-started/ 前言 之前整理了一篇關於Less的,現在就來整理一下關於Sass的。 因為這兩種都是CSS的主流預處理器,當然還有Stylus。 要解釋一下什麼是Sass嗎? Sas ...
  • 一、變數作用域 變數作用域指的是變數的作用範圍,javascript中的變數分為全局變數和局部變數 1、全局變數:在函數之外定義的變數,為整個頁面公用,函數的內部外部都可以訪問。 2、局部變數:在函數內部定義的變數,只能在定義該變數的函數內部訪問,外部無法訪問。函數內部訪問變數時,先在內部查找是否有 ...
  • 在前面,我們學習了標準文檔流,但在實際製作的過程中,用標準文檔流書寫顯然是不現實的,因此,我們來瞭解幾種脫離標準文檔流的方法: 1.float 浮動 float:left/right;(左浮/右浮) 效果:元素都加浮動,後面的元素緊跟前面的元素併排排列 第一個加了float,脫離了標準文檔流,對於瀏 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...