vue-i18n国际化插件安装教程(Vue3篇)

i18n是一个国际化语言插件,意译为internationalization的缩写,代表头尾字母加上十八个字母

1,下载i18n,选择一种安装方式就行

pnpm add vue-i18n

yarn add vue-i18n

npm install vue-i18n

2,配置i18n

创造一个i18n文件夹,放在utils或随便一个地方都行,小编推荐单独src目录下的i18n文件夹,因为工作量可能很大

javascript 复制代码
// src/i18n/index.ts
import { createI18n } from "vue-i18n";
import en from './langs/en'
import zh from './langs/zh'

const messages = {
    en,
    zh
}

const i18n = createI18n({
    legacy: false, // vue3需要false 默认模式
    locale: 'zh',
    messages // 翻译语言包
})

export default i18n

legacy在vue3中需要开启false,不然会报错

lacale是本地默认语言,zh:中文 en:英文

messages是翻译语言包,防止中文和英文

我们为了方便把messages提出来放,考虑到语言工程量很大,再单独放置两种语言包在/src/i18n/langs/en.ts和/src/i18n/langs/zh.ts中

3,在main.ts中挂载使用

javascript 复制代码
/main.ts
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import i18n from './i18n/index.ts'


const app = createApp(App)
app.use(router).use(i18n).mount('#app')
相关推荐
陈随易14 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星14 小时前
javascript之事件代理/事件委托
前端
@yanyu66615 小时前
登录注册功能-明文
vue.js·springboot
陈随易15 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
里欧跑得慢17 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒18 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
cn_mengbei18 小时前
用React Native开发OpenHarmony应用:Reanimated共享元素过渡
javascript·react native·react.js
kyriewen18 小时前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真18 小时前
我自己写的第一个skills--project-core-standards
前端·agent
Data_Journal18 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库