first commit
This commit is contained in:
commit
aa0966c4e6
70
README.md
Normal file
70
README.md
Normal file
@ -0,0 +1,70 @@
|
||||
# 🐤 kiwi-intl [](http://badge.fury.io/js/kiwi-intl)
|
||||
|
||||
通用的国际化框架,不绑定任何框架。
|
||||
|
||||
## 如何使用
|
||||
|
||||
> yarn add kiwi-intl
|
||||
|
||||
> 推荐与[🐤 Kiwi-国际化全流程解决方案](https://github.com/alibaba/kiwi)结合使用
|
||||
|
||||
## 使用 API
|
||||
|
||||
初始化国际化框架
|
||||
|
||||
```javascript
|
||||
import KiwiIntl from 'kiwi-intl';
|
||||
|
||||
const kiwiIntl = KiwiIntl.init('en-UK', {
|
||||
'en-UK': {
|
||||
test: 'testvalue',
|
||||
testTemplate: 'you have {value} unread message',
|
||||
photo:
|
||||
'You have {num, plural, =0 {no photos.} =1 {one photo.} other {# photos.}}'
|
||||
},
|
||||
'zh-CN': {
|
||||
lang: '语言'
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
在组件中直接使用,支持模板, 单复数。同时支持 `kiwiIntl.test`,直接取对应 Key 值。
|
||||
|
||||
```javascript
|
||||
|
||||
kiwiIntl.test; // testvalue;
|
||||
|
||||
kiwiIntl.get('test'); // testvalue;
|
||||
|
||||
kiwiIntl.get('testTemplate', {
|
||||
value: three
|
||||
}); // 值是 'you have three unread message'
|
||||
|
||||
kiwiIntl.template(kiwiIntl.testTemplate, {
|
||||
value: three
|
||||
}); // 值是 'you have three unread message'
|
||||
|
||||
kiwiIntl.get('photo', {
|
||||
num: 0
|
||||
}); // 值是 'You have no photos.'
|
||||
```
|
||||
|
||||
切换语言
|
||||
|
||||
```javascript
|
||||
kiwiIntl.setLang('zh-CN'); // 切换到中文语言
|
||||
```
|
||||
## 语言编码
|
||||
【强制】区别不同语言的 language tag 遵循 [BCP47](https://en.wikipedia.org/wiki/IETF_language_tag) 规范。
|
||||
|
||||
根据目前的国际业务情况,不同地区的同种语言在同一地区不会同使用两种写法。比如新加坡只使用是简体中文,台湾和香港只使用繁体中文,所以我们约定在 BCP 47规范中,仅使用 language-region 的组合方式。
|
||||
|
||||
正例:zh-CN
|
||||
|
||||
反例:~~zh、zh_hans、zh-cn~~
|
||||
|
||||
|
||||
|
||||
## License
|
||||
|
||||
MIT
|
Loading…
x
Reference in New Issue
Block a user