| # egg-i18n | 
|   | 
| [![NPM version][npm-image]][npm-url] | 
| [![build status][travis-image]][travis-url] | 
| [![Test coverage][codecov-image]][codecov-url] | 
| [![David deps][david-image]][david-url] | 
| [![Known Vulnerabilities][snyk-image]][snyk-url] | 
| [![npm download][download-image]][download-url] | 
|   | 
| [npm-image]: https://img.shields.io/npm/v/egg-i18n.svg?style=flat-square | 
| [npm-url]: https://npmjs.org/package/egg-i18n | 
| [travis-image]: https://img.shields.io/travis/eggjs/egg-i18n.svg?style=flat-square | 
| [travis-url]: https://travis-ci.org/eggjs/egg-i18n | 
| [codecov-image]: https://codecov.io/github/eggjs/egg-i18n/coverage.svg?branch=master | 
| [codecov-url]: https://codecov.io/github/eggjs/egg-i18n?branch=master | 
| [david-image]: https://img.shields.io/david/eggjs/egg-i18n.svg?style=flat-square | 
| [david-url]: https://david-dm.org/eggjs/egg-i18n | 
| [snyk-image]: https://snyk.io/test/npm/egg-i18n/badge.svg?style=flat-square | 
| [snyk-url]: https://snyk.io/test/npm/egg-i18n | 
| [download-image]: https://img.shields.io/npm/dm/egg-i18n.svg?style=flat-square | 
| [download-url]: https://npmjs.org/package/egg-i18n | 
|   | 
| 可以为你的应用提供多语言的特性 | 
|   | 
| ## 功能 | 
|   | 
| - 支持多种语言独立配置,统一存放在 config/locale/\*.js 下( 兼容 `config/locales/*.js` ); | 
| - 提供 Middleware 为 View 提供 `\_\_`, `gettext` 函数获取多语言文案; | 
| - 基于 URL 参数 `locale` 修改语言显示,同时会记录到 Cookie,下次请求会用 Cookie 里面的语言方案。 | 
|   | 
| ## 配置 | 
|   | 
| 默认处于关闭状态,你需要在 `config/plugin.js` 开启它: | 
|   | 
| ```js | 
| // config/plugin.js | 
| exports.i18n = { | 
|   enable: true, | 
|   package: 'egg-i18n', | 
| }; | 
| ``` | 
|   | 
| 你可以修改 `config/config.default.js` 来设定 i18n 的配置项: | 
|   | 
| ```js | 
| // config/config.default.js | 
| exports.i18n = { | 
|   // 默认语言,默认 "en_US" | 
|   defaultLocale: 'zh-CN', | 
|   // URL 参数,默认 "locale" | 
|   queryField: 'locale', | 
|   // Cookie 记录的 key, 默认:"locale" | 
|   cookieField: 'locale', | 
|   // Cookie 的 domain 配置,默认为空,代表当前域名有效 | 
|   cookieDomain: '', | 
|   // Cookie 默认 `1y` 一年后过期, 如果设置为 Number,则单位为 ms | 
|   cookieMaxAge: '1y', | 
| }; | 
| ``` | 
|   | 
| 其实大部分时候,你只需要修改一下 `defaultLocale` 设定默认的语言。 | 
|   | 
| ## 编写你的 I18n 多语言文件 | 
|   | 
| ```js | 
| // config/locale/zh-CN.js | 
| module.exports = { | 
|   "Email": "邮箱", | 
|   "Welcome back, %s!": "欢迎回来,%s!", | 
|   "Hello %s, how are you today?": "你好 %s, 今天过得咋样?", | 
| }; | 
| ``` | 
|   | 
| ```js | 
| // config/locale/en-US.js | 
| module.exports = { | 
|   "Email": "Email", | 
| }; | 
| ``` | 
|   | 
| 或者也可以用 JSON 格式的文件: | 
|   | 
| ```json | 
| // config/locale/zh-CN.json | 
| { | 
|   "email": "邮箱", | 
|   "login": "帐号", | 
|   "createdAt": "注册时间" | 
| } | 
| ``` | 
|   | 
| ## 使用 I18n 函数获取语言文本 | 
|   | 
| I18n 为你提供 `__` (Alias: `gettext`) 函数,让你可以轻松获得 locale 文件夹下面的多语言文本。 | 
|   | 
| > NOTE: __ 是两个下划线哦! | 
|   | 
| - ctx.__ = function (key, value[, value2, ...]): 类似 util.format 接口 | 
| - ctx.__ = function (key, values): 支持数组下标占位符方式,如 | 
|   | 
| ```js | 
| ctx.__('{0} {0} {1} {1}'), ['foo', 'bar']) | 
| ctx.gettext('{0} {0} {1} {1}'), ['foo', 'bar']) | 
| => | 
| foo foo bar bar | 
| ``` | 
|   | 
| ### Controllers 下的使用示例 | 
|   | 
| ```js | 
| module.exports = function* () { | 
|   this.body = { | 
|     message: this.__('Welcome back, %s!', this.user.name) | 
|     // 或者使用 gettext,如果觉得 __ 不好看的话 | 
|     // message: this.gettext('Welcome back, %s!', this.user.name) | 
|     user: this.user, | 
|   }; | 
| }; | 
| ``` | 
|   | 
| ### View 文件下的使用示例 | 
|   | 
| ```html | 
| <li>{{ __('Email') }}: {{ user.email }}</li> | 
| <li> | 
|   {{ __('Hello %s, how are you today?', user.name) }} | 
| </li> | 
| <li> | 
|   {{ __('{0} {0} {1} {1}'), ['foo', 'bar']) }} | 
| </li> | 
| ``` | 
|   | 
| ### 修改应用的默认语言 | 
|   | 
| 你可以用下面几种方式修改应用的当前语言(修改或会记录到 Cookie),下次请求直接用设定好的语言。 | 
|   | 
| 优先级从上到下: | 
|   | 
| - query: /?locale=en-US | 
| - cookie: locale=zh-TW | 
| - header: Accept-Language: zh-CN,zh;q=0.5 |