@i18n-pro/react
Version:
An out-of-the-box, lightweight i18n auto-translation solution for React
121 lines (85 loc) • 4.61 kB
Markdown
<div align="center">
<p style="font-size: 18px;">An out-of-the-box, lightweight i18n auto-translation solution for React</p>
English | [简体中文](https://github.com/i18n-pro/react/blob/v2.0.0-alpha.2/README_zh-CN.md)
[](https://www.npmjs.com/package/@i18n-pro/react "npm")
[](https://www.npmjs.com/package/@i18n-pro/react "npm")
[](https://github.com/i18n-pro/react/stargazers "github-stars")
[](https://github.com/i18n-pro/react/commits/main "last-commit")
[](https://github.com/i18n-pro/react/issues "github-issues")
[](https://codecov.io/gh/i18n-pro/react "codecov")

</div>
<details >
<summary>Table of Contents</summary>
[Vision](#vision)<br/>
[Requirement](#requirement)<br/>
[Features](#features)<br/>
[Live Demo](#live-demo)<br/>
[Principle](#principle)<br/>
[License](#license)<br/>
</details>
# Vision
To make internationalization easy and enjoyable 😄💪🏻
# Requirement
* react >= **16.8.0**
* react-dom >= **16.8.0**
* react-native >= **0.59.0**
* i18n-pro >= **3.0.0** < **4.0.0**
# Features
* **lightweight**:[](https://bundlephobia.com/package/i18n-pro "i18n-pro-bundlesize") + [](https://bundlephobia.com/package/@i18n-pro/react "bundlesize")
* The following features are inherited from [i18n-pro](https://github.com/i18n-pro/core "i18n-pro")
* **simple**
* **flexible**
* **automatic-translation**
* **keyless**
# Live Demo
* [Open in CodeSandbox](https://codesandbox.io/p/github/i18n-pro/react-demo/v2?file=README.md)
* [](https://stackblitz.com/github/i18n-pro/react-demo/tree/v2?file=README.md)
# Principle
This library is implemented based on [i18n-pro](https://github.com/i18n-pro/core "i18n-pro") combined with `React` 's `context` feature
Mainly composed of `2` parts
* I18nProvider
* useI18n
**I18nProvider**:Configure container components for internationalization initialization properties
**useI18n**:Hook method for obtaining internationalization API and state
A simple example is as follows
```typescript react
import React from 'react'
import { render } from 'react-dom'
import { I18nProvider, useI18n } from '@i18n-pro/react'
function App() {
const { t } = useI18n()
return <>{t('hello world')}</>
}
render(
<I18nProvider
namespace="i18n-example"
locale="en"
langs={{
zh: {
'hello world': '你好世界',
},
ja:{
"hello world": "こんにちは世界",
},
}}
>
<App />
</I18nProvider>,
document.getElementById('root'),
)
```
# Help Document
>To avoid unnecessary duplicate document content, some of the documents in this library are linked to the content in `i18n-pro` <br />The `i18n-pro` related link in the current document is based on the `3.0.0-alpha.1` version. If you are using a different version, you need to check the document corresponding to the version you are using to avoid inconsistent usage
* Current Library
* [Quick Start](https://github.com/i18n-pro/react/blob/v2.0.0-alpha.2/docs/dist/USAGE.md)
* [API](https://github.com/i18n-pro/react/blob/v2.0.0-alpha.2/docs/dist/API.md)
* [Changelog](https://github.com/i18n-pro/react/blob/v2.0.0-alpha.2/docs/dist/CHANGELOG.md)
* i18n-pro
* [Command Line](https://github.com/i18n-pro/core/blob/v3.0.0-alpha.1/docs/dist/COMMAND_LINE.md)
* [Matching Rules](https://github.com/i18n-pro/core/blob/v3.0.0-alpha.1/docs/dist/MATCH_RULE.md)
* [Q&A](https://github.com/i18n-pro/core/blob/v3.0.0-alpha.1/docs/dist/Q&A.md)
* [Translation log](https://github.com/i18n-pro/core/blob/v3.0.0-alpha.1/docs/dist/OUTPUT_LOG.md)
# License
[MIT](./LICENSE)
Copyright (c) 2023-present Eyelly Wu