vue内i18n国际化移动端引入及使用

实现中英文切换,我使用的版本

"vue": "^3.5.13",

"vue-i18n": "9",

下载i18n依赖

main.ts/js

复制代码
import i18n from './locales' // 引入我们配置好的 i18n
const app = createApp(App)
app.use(i18n) // 使用插件

vue页面使用

复制代码
import { useI18n } from 'vue-i18n'
const { t } = useI18n();
            <span class="text-green-600 font-bold">{{ t('RechargeSuccess') }}</span>
  <van-cell-group>
          <van-field v-model="orderNumber" :label="t('TransactionNumber')" :placeholder="t('PleaseEnterTransactionNumber')" clearable />
          <!-- 日期选择器 -->
          <van-field is-link readonly :label="t('DateRange')" :model-value="dateRangeText" :placeholder="t('PleaseSelectDateRange')"
            @click="showCalendar = true" />
        </van-cell-group>

locales文件夹下的zh-cn.json,没有新建

复制代码
{
  "HomePage": "首页",
  "Language": "语言切换",}

en.json

复制代码
{
  "HomePage": "Home",
  "Language": "Language ",}

locales文件夹下的index.js

复制代码
import { createI18n } from 'vue-i18n'
import { ref } from 'vue'

// 导入语言包
import zhCN from './zh-cn.json'
import enUS from './en.json'

// 支持的语言类型
export type Locale = 'zh-cn' | 'en'

// 创建 i18n 实例
const i18n = createI18n({
  legacy: false, // 必须为 false,使用 Composition API
  locale: localStorage.getItem('locale') || 'zh-cn', // 默认语言
  fallbackLocale: 'zh-cn', // 回退语言
  messages: {
    'zh-cn': zhCN,
    'en': enUS,
  },
})

export default i18n
相关推荐
明月_清风9 小时前
自定义右键菜单:在项目里实现“选中文字即刻生成新提示”
前端·javascript
明月_清风9 小时前
告别后端转换:高质量批量导出实战
前端·javascript
刘发财13 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶16 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶16 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
Kagol18 小时前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路20 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide20 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter20 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸21 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端