Skip to content

Moonlightwsn/taro-vue-i18n-lite

Repository files navigation

taro-vue-i18n-lite

轻量级国际化插件 Taro Vue3 版本

安装

在 Taro 项目根目录下安装

npm i taro-vue-i18n-lite
# 或使用yarn
yarn add taro-vue-i18n-lite
# 或使用pnpm
pnpm add taro-vue-i18n-lite

快速上手

Typescript 支持

修改tsconfig.json

{
  "include": ["node_modules/taro-vue-i18n-lite/typings"]
}

安装插件

import { createApp } from "vue"
import i18n from "taro-vue-i18n-lite"

// 定义国际化文本
const messages = {
  "zh-CN": {
    say: {
      hi: "嗨~",
    },
  },
  "en-US": {
    say: {
      hi: "Hi~",
    },
  },
}

// 通过 `App.use()` 安装 `Vue` 插件:`taro-vue-i18n-lite`
const App = createApp({})
App.use(i18n, {
  locale: "zh-CN",
  messages,
})

视图中使用

<template>
  <div>{{ $t("say.hi") }}</div>
</template>
<script setup></script>

输出

<div>嗨~</div>

更多用法

动态切换语言

<template>
  <div>{{ $t("say.hi") }}</div>
  <button @click="changeLocale">点我切换语言</button>
</template>
<script setup>
  import { useI18n } from "taro-vue-i18n-lite"

  const i18n = useI18n()

  const changeLocale = () => {
    const currentLocale = i18n.getCurrentLocale()
    i18n.changeLocale(currentLocale === "zh-CN" ? "en-US" : "zh-CN")
  }
</script>

JS/TS 中翻译文本

<template>
  <div>{{ hi }}</div>
  <button @click="translate">点我翻译</button>
</template>
<script setup>
  import { ref } from "vue"
  import { useI18n } from "taro-vue-i18n-lite"

  const i18n = useI18n()

  const hi = ref("say.hi")

  const translate = () => {
    hi.value = i18n.t("say.hi")
  }
</script>

输出由

<div>say.hi</div>

变为

<div>嗨~</div>

动态参数

// 定义国际化文本
const messages = {
  "zh-CN": {
    say: {
      hi: "嗨~ {name}",
    },
  },
  "en-US": {
    say: {
      hi: "Hi~ {name}",
    },
  },
}
<div>{{ $t("say.hi", { name: 'i18n' }) }}</div>

输出

<div>嗨~ i18n</div>

配合 UI 组件

NutUI 为例,配合 taro-vue-i18n-lite 使用:

安装 NutUI 参考指南 快速上手

import { createApp } from "vue"
import { Locale } from "@nutui/nutui-taro"
import i18n from "taro-vue-i18n-lite"

import enUS from "@nutui/nutui-taro/dist/packages/locale/lang/en-US"
import zhCN from "@nutui/nutui-taro/dist/packages/locale/lang/zh-CN"

const App = createApp({})

const messages = {
  "zh-CN": {
    say: {
      hi: "嗨~ {name}",
      goodbye: "再见!",
    },
  },
  "en-US": {
    say: {
      hi: "Hi~ {name}",
      goodbye: "Goodbye!",
    },
  },
}

App.use(i18n, {
  locale: "zh-CN",
  messages,
  onInstall: (locale: string) => {
    Locale.use(locale, locale === "zh-CN" ? zhCN : enUS)
  },
  onChange: (locale: string) => {
    Locale.use(locale, locale === "zh-CN" ? zhCN : enUS)
  },
})

交流

如果你有新的功能需求或者想参与到这个国际化插件的开发中,欢迎提 Issue或添加我的好友

QQ: 543456277

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published