• 快速入门
    • 概览
    • 安装
    • 使用
      • i18n文本定义
      • WXML 中的用法
      • JavaScript 中的用法
      • 构建
    • 特性
      • 文本插值
      • select 语句

    快速入门

    概览

    miniprogram-i18n 的用法主要分为四部分。分别是:构建脚本与i18配置、i18n文本定义、WXML中的用法及JavaScript中的用法。

    安装

    该方案目前需要依赖 Gulp 并且对源文件目录结构有一定的要求,需要确保小程序源文件放置在特定目录下(例如 src/ 目录)。

    • 首先在项目根目录运行以下命令安装 gulp 及 miniprogram-i18n 的 gulp 插件。
    1. npm i -D gulp @miniprogram-i18n/gulp-i18n-locales @miniprogram-i18n/gulp-i18n-wxml
    • 在小程序运行环境下安装国际化运行时并在开发工具"构建npm"。
    1. npm i -S @miniprogram-i18n/core
    • 在项目根目录新建 gulpfile.js,并编写构建脚本,可参考 examples/gulpfile.js。

    更多 Gulp 相关配置请参考 Gulp插件配置文档。

    使用

    i18n文本定义

    miniprogram-i18n 目前采用 JSON 文件对 i18n 文本进行定义。使用之前,需要在项目源文件下新建 i18n 目录。

    目录结构如下:

    1. ├── dist // 小程序构建目录
    2. ├── gulpfile.js
    3. ├── node_modules
    4. ├── package.json
    5. └── src // 小程序源文件目录
    6. | ├── app.js
    7. | ├── app.json
    8. | ├── app.wxss
    9. | ├── i18n // 国际化文本目录
    10. | | ├── en-US.json
    11. | | └── zh-CN.json

    i18n 目录可以放置在源文件目录下的任意位置,例如可以跟 Page 或 Component 放在一起。但是需要注意的是,多个 i18n 目录下的文件在构建时会被合并打包,因此如果翻译文本有重复的 key 可能会发生覆盖。如果分开多个 i18n 目录定义需要自行确保 key 是全局唯一的。例如使用 page.index.testKey 这样的能确保唯一的名称。

    下面我们定义文本:

    1. // i18n/en-US.json
    2. {
    3. "plainText": "This is a plain text",
    4. "withParams": "{value} is what you pass in"
    5. }
    1. // i18n/zh-CN.json
    2. {
    3. "plainText": "这是一段纯文本",
    4. "withParams": "你传入的值是{value}"
    5. }

    WXML 中的用法

    定义好 i18n 文本之后,就可以在 WXML 文件里使用了。首先,需要在 WXML 文件对应的 JavaScript 文件里引入国际化运行时。

    1. // pages/index/index.js
    2. import { I18n } from '@miniprogram-i18n/core'
    3. Component({
    4. behaviors: [I18n]
    5. })

    注意:这里建议 Page 以及 Component 都采用 Component 构造器进行定义,这样可以使用 I18n 这个 Behavior。如果需要在 Page 构造上使用 I18n 则需要引入 I18nPage 代替 Page 构造器。

    接着可以在 WXML 文件中获取预先定义好的 i18n 文本。

    1. <!-- pages/index/index.wxml -->
    2. <view>{{ t('plainText') }}</view>
    3. <input placeholder="{{ t('withParams', {value}) }}"></input>

    在 WXML 中使用 t 函数(或其他你指定的函数名)来获取文本。 t函数签名如下:

    1. t(key: string, params: object)

    它可以接受两个参数,第一个参数是 i18n 文本的 key,第二个参数是需要传入的插值对象(可以是从 AppService 传过来的值)。

    JavaScript 中的用法

    在 JavaScript 里可以直接引用 @miniprogram-i18n/core 这个 NPM 包来获取翻译文本。

    1. import { getI18nInstance } from '@miniprogram-i18n/core'
    2. const i18n = getI18nInstance()
    3. Component({
    4. attached() {
    5. const text = i18n.t('withParams', { value: 'Test' })
    6. console.log(text) // Test is what you pass in
    7. i18n.setLocale('en-US')
    8. }
    9. })

    同样的,在 i18n 实例上,还暴露了其他一些接口,例如获取当前语言、动态设置当前语言等。具体接口请参考 接口文档。

    如果你的 JavaScript 对应的 WXML 里已经使用了国际化文本,换言之,即 Component 构造器已经引入了 I18n Behavior,那么所有的实例方法都会被直接挂载到 this 上,你可以通过 this 调用它们。

    1. import { I18n } from '@miniprogram-i18n/core'
    2. Component({
    3. behaviors: [I18n],
    4. attached() {
    5. const text = this.t('withParams', { value: 'Test' })
    6. console.log(text) // Test is what you pass in
    7. this.setLocale('en-US')
    8. }
    9. })

    构建

    在编写完 i18n 文本并在 WXML 或 JavaScript 中调用之后,你需要运行 gulp 命令对 .wxml 文件进行转译并对 i18n 文本进行打包合并。

    特性

    目前 miniprogram-i18n 仅支持纯文本及文本插值,后续会对其他 i18n 特性进行支持。

    文本插值

    1. {
    2. "key": "Inserted value: {value}"
    3. }
    1. i18n.t('key', { value: 'Hello!' }) // Inserted value: Hello!

    为了方便调用深层嵌套的对象,当前支持使用 . 点语法来访问对象属性。

    1. {
    2. "dotted": "Nested value is: { obj.nested.value }"
    3. }
    1. const value = {
    2. obj: {
    3. nested: {
    4. value: 'Catch you!'
    5. }
    6. }
    7. }
    8. i18n.t('dotted', value) // Nested value is: Catch you!

    select 语句

    1. {
    2. "key": "{gender, select, male {His inbox} female {Her inbox} other {Their inbox}}"
    3. }
    1. i18n.t('key', { gender: 'male' }) // His inbox
    2. i18n.t('key', { gender: 'female' }) // Her inbox
    3. i18n.t('key') // Their inbox

    select 语句支持子语句文本插值:

    1. {
    2. "key": "{mood, select, good {{how} day!} sad {{how} day.} other {Whatever!}}"
    3. }
    1. i18n.t('key', { mood: 'good', how: 'Awesome' }) // Awesome day!
    2. i18n.t('key', { mood: 'sad', how: 'Unhappy' }) // Unhappy day.
    3. i18n.t('key') // Whatever!

    注:select 语句支持子句嵌套 select 语句

    其他尚未支持的特性有:

    • Pseudo 字符串

    • 单复数处理

    • 日期、数字、货币处理

    • 定义文件的命名空间

    • 支持 WXML 与 JavaScript 独立定义