vite+vue-ts 如何在项目中实现多语言

开源库:github.com/intlify/vue...

插件:github.com/intlify/bun...

安装插件:pnpm add vue-i18n @intlify/unplugin-vue-i18n

配置vite

ts 复制代码
// vite.config.ts
import VueI18nPlugin from '@intlify/unplugin-vue-i18n/vite'
export default defineConfig({
...
  plugins: [
  ...
  VueI18nPlugin({
      include: [resolve(__dirname, './src/locales/**')],
    }),
  ]
})

创建文件

目录结构 复制代码
src/
├── locales/
│   ├── en.json
│   ├── zh.json

添加en.json数据

json 复制代码
 
{
    "language": "English",
    "lang": {
        "zh-CN": "Chinese",
        "en-US": "English"
    },
    "home": {
        "welcome": "welcome",
        "loading": "loading..."
    }
}

添加zh.json数据

json 复制代码
{
    "language": "中文",
    "lang": {
        "zh-CN": "中文",
        "en-US": "英文"
    },
    "home": {
        "welcome": "欢迎使用",
        "loading": "加载中..."
    }
}

将数据加载到项目中

ts 复制代码
// main.ts
import { createI18n } from 'vue-i18n'
import messages from '@intlify/unplugin-vue-i18n/messages'

const locale = localStorage.getItem("i18n-locale") || 'zh-CN'
const i18n = createI18n({
  locale: locale,
  fallbackLocale: 'en-US',
  messages: messages
})

const app = createApp(App)
app.use(i18n)
app.mount('#app')

实现多语言切换 案例:

vue 复制代码
<template>
    <el-dropdown placement="bottom" style="margin-right: 20px;cursor: pointer;" @command="selectLang">
        <span>语言({{ t('language') }})</span>
        <template #dropdown>
            <el-dropdown-menu>
                <el-dropdown-item command="zh-CN">中文</el-dropdown-item>
                <el-dropdown-item command="en-US">English</el-dropdown-item>
            </el-dropdown-menu>
        </template>
    </el-dropdown>
</template>
<script lang="ts" setup>
import { useI18n } from 'vue-i18n'
const { t, locale } = useI18n()
const selectLang = (lang: string) => {
    locale.value = lang
    localStorage.setItem('i18n-locale', lang)
}
</script>
<style scoped></style>

实现方式很简单,目前还没有发现缺陷,有更好的方案请求大家多多指导

相关推荐
憧憬成为web高手5 小时前
ACTF 12307复现
前端·bootstrap·html
wordbaby6 小时前
Axios 上传大文件崩溃:鸿蒙 RNOH 下 XHR 返回空响应头引发的"假失败"
前端·react native
wordbaby6 小时前
React Native 列表分页实战:下拉刷新与上拉加载的工程化方案
前端·react native
wordbaby7 小时前
脱离 Tab 栏的艺术:React Native 全屏子页面的导航架构实践
前端·react native·harmonyos
陈随易7 小时前
Redis 8.8发布,一定要更新
前端·后端·程序员
wordbaby7 小时前
React Native 新架构落地鸿蒙:跨三端政务级应用的工程实践与深度复盘
前端·react native·harmonyos
晓说前端7 小时前
第一篇:为什么学TypeScript?—— 优势、场景与环境搭建
javascript·ubuntu·typescript
excel9 小时前
为什么我推荐使用 Termius:现代 SSH 工具的完整体验
前端·后端
ZC跨境爬虫9 小时前
模块化烹饪小程序开发日记 Day7:(菜谱详情接口开发与JSON数据读取全流程)
前端·javascript·css·ui·微信小程序·json
এ慕ོ冬℘゜9 小时前
JS 前端基础面试题
开发语言·前端·javascript