源碼地址 : vue-i18n-demo
安裝 vue-i18nhtml
npm install vue-i18n --save-dev
新建中英文對照文件vue
// zh.js module.exports = { language: { name: "中文", current: "當前語言" }, navbar: { home: "首頁", about: "關於咱們", join: "加入咱們", contact: "聯繫咱們" } }; // en.js module.exports = { language: { name: "English", current: "Current Language" }, navbar: { home: "Home", about: "About", join: "Join Us", contact: "Contact Us" } };
在 main.js 文件引入git
// main.js import VueI18n from "vue-i18n"; Vue.use(VueI18n); const i18n = new VueI18n({ locale: localStorage.getItem("lang") || "zh", messages: { zh: require("./assets/i18n/zh"), en: require("./assets/i18n/en") } }); new Vue({ router, i18n, render: h => h(App) }).$mount("#app");
使用github
<template> <div> <ul class="lang" @click="changeLang"> <li :class="isActive?'active':''">zh</li>/ <li :class="!isActive?'active':''">en</li> </ul> <div>{{$t('language.current')}}:{{$t('language.name')}}</div> <ul> <li>{{ $t('navbar.home') }}</li> <li>{{ $t('navbar.about') }}</li> <li>{{ $t('navbar.join') }}</li> <li>{{ $t('navbar.contact') }}</li> </ul> </div> </template> <script> export default { name: "I18nDemo", data() { return { isActive: true }; }, created() { let lang = document.documentElement.lang; localStorage.setItem("lang", lang); this.toActive(lang); }, methods: { changeLang(e) { let lang = e.target.innerText; this.$i18n.locale = lang; this.toActive(lang); }, toActive(lang) { this.isActive = lang == "zh" ? true : false; } } }; </script>
注:
$t
是固定用法