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')
相关推荐
普宁彭于晏几秒前
元素水平垂直居中的方法
前端·css·笔记·css3
恋猫de小郭12 分钟前
为什么跨平台框架可以适配鸿蒙,它们的技术原理是什么?
android·前端·flutter
云浪15 分钟前
元素变形记:CSS 缩放函数全指南
前端·css
明似水30 分钟前
用 Melos 解决 Flutter Monorepo 的依赖冲突:一个真实案例
前端·javascript·flutter
独立开阀者_FwtCoder40 分钟前
stagewise:让AI与代码编辑器无缝连接
前端·javascript·github
清沫42 分钟前
Cursor Rules 开发实践指南
前端·ai编程·cursor
江城开朗的豌豆1 小时前
JavaScript篇:对象派 vs 过程派:编程江湖的两种武功心法
前端·javascript·面试
不吃糖葫芦31 小时前
App使用webview套壳引入h5(二)—— app内访问h5,顶部被手机顶部菜单遮挡问题,保留顶部安全距离
前端·webview
菥菥爱嘻嘻1 小时前
JS手写代码篇---手写ajax
开发语言·javascript·ajax
江城开朗的豌豆1 小时前
JavaScript篇:字母侦探:如何快速统计字符串里谁才是'主角'?
前端·javascript·面试