如何在Vue3中配置国际化语言i18n

1. 安装 vue-i18n

js 复制代码
npm i vue-i18n -S

2. 创建一个i8n的配置文件 如:i18nConfig.js

js 复制代码
// 配置 vue-i18n 实现国际化语言设置
import { createI19n } from 'vue-i18n'

import zh_cn from '../language/zh-CN'
import en_us from '../language/en-US'
import CONFIG from '../../confing'

const messages = {
	// 目前只配置了中英两种语言
	'zhCn': zh_cn,
	'en': en_US
}

const lang = CONFIG.locale

const i18n = createI18n({
	legacy: false,
	locale: lang, // 选择使用哪种语言
	messages
})

export default i18n

3. 新建语言文件 zh-CN.js 和 en-US.js

  • zh-CN.js 文件
js 复制代码
// zh-CN.js 文件
const zh = {
	hello: '你好',
	// 根据业务需要,还可以分组规划,让代码更清晰
	homeModule: {
		hi: '嗨'
	}
}

export default zh
  • en-US.js 文件
js 复制代码
// en-US.js 文件
const en = {
	hello: 'hello',
	// 根据业务需要,还可以分组规划,让代码更清晰
	homeModule: {
		hi: 'hi'
	}
}

export default en
  • CONFIG.js 文件
js 复制代码
// CONFIG.js 文件
const CONFIG = {
	locale: 'zhCN' // zhCn ------ 中文,en ------ 英文
}

export default CONFIG

4. 在 main.js 里面全局配置

js 复制代码
// main.js 文件
......
import i18n from '../src/language/i18nConfig'
......

app.use(i18n)

......

通过上面四步即可配置完毕

下面说一下如何使用,分三种情况

  1. 在 .vue 组件中的 template 使用
html 复制代码
<template>
	<div>{{ $t('hello') }}</div>
	<div>{{ $t('homeModule.hi') }}</div>
</template>
  1. 在 .vue 组件中的 script 中使用
js 复制代码
<script setup>
	const instance = getCurrentInstance() // 获取当前组件实例
	const $t = instance.appContext.config.globalProperties.$t
	console.log($t('hello'))
	console.log($t('homeModule.hi'))
</script>
  1. 在 .js 文件中使用
js 复制代码
import i18n from '/src/language/i18nConfig'
const $t = i18n.global.t
console.log($t('hello'))
console.log($t('homeModule.hi'))

本文到此便已经记录完毕,仅作为对工作中遇到的一些问题的记录,方便后面翻看,如有大佬有更好的方法,感谢不吝赐教!!!

相关推荐
棋子一名1 天前
跑马灯组件 Vue2/Vue3/uni-app/微信小程序
微信小程序·小程序·uni-app·vue·js
EterNity_TiMe_3 天前
上手 Rokid JSAR:新手也能快速入门的 AR 开发之旅
ar·js·rokid
昔冰_G4 天前
Vue内置组件KeepAlive——缓存组件实例
vue.js·缓存·vue3·vue2·keep-alive·vue组件缓存·vue内置组件
TeleostNaCl4 天前
实战 | 使用 Chrome 开发者工具修改网页源码跳过前端校验
前端·chrome·经验分享·后端·js
wxr06166 天前
部署Spring Boot项目+mysql并允许前端本地访问的步骤
前端·javascript·vue.js·阿里云·vue3·springboot
知识分享小能手7 天前
微信小程序入门学习教程,从入门到精通,微信小程序开发进阶(7)
前端·javascript·学习·程序人生·微信小程序·小程序·vue3
吹晚风吧10 天前
什么是跨域?跨域怎么解决?跨域解决的是什么问题?
java·vue.js·js·cors
红烧code10 天前
【Rust GUI开发入门】编写一个本地音乐播放器(12. 国际化应用-多语言支持)
rust·i18n·gui·slint
~无忧花开~12 天前
JavaScript学习笔记(十五):ES6模板字符串使用指南
开发语言·前端·javascript·vue.js·学习·es6·js
~无忧花开~12 天前
JavaScript学习笔记(十七):ES6生成器函数详解
开发语言·前端·javascript·笔记·学习·es6·js