ホームページ >ウェブフロントエンド >jsチュートリアル >React-intl実装の多言語例を詳しく解説
言語の国際化機能が最近プロジェクトに追加されました。この記事では主に React-intl で多言語を実装するためのサンプルコードを紹介します。編集者が非常に良いと思ったので、参考として共有します。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。
言語の国際化 (言語のローカリゼーションと呼ぶ人もいます) は、実際には、Web アプリに複数の言語を追加することです。論理的に言えば、「逐語的な置き換え」ではありません。しかし、そのような低コストのアプローチで利益が得られるでしょうか?
最初に、プロジェクト全体に設定ファイルを追加する従来の方法を検討しましたが、異なる言語と地域に応じて、異なる設定ファイルをロードすることで、インターフェース言語の切り替えの目的を達成できます。もちろん、このアイデアが「初期」アイデアと呼ばれるのは、まさにこのアイデアが単純すぎるためです。言語の国際化とは、インターフェース上のUIテキストを別の言語に翻訳するだけでなく、日付と時刻の表示、数値表示(英語環境では3桁ごとにカンマ:1,000)、数量詞の表示(リンゴ)も含まれます。 . はリンゴ、2 つのリンゴはリンゴである必要があります)、文字列の途中に変数が挿入される場合もあります (「今日のランチに {count} 個のチキンドラムスティックを食べました」)...
これは単純な文字置換の問題ではなく、ディレクトリを簡単にエクスポートして Word またはページに配置し、他の同僚が翻訳作業のために比較できるようにする必要があります。これは非常に重要です。 !プロダクト マネージャーにコードを直接変更してもらいたいですか?それとも一つずつ検索して置換しますか?よく考えずにただやるだけなら、その代償はあなたが払うことになると信じてください。
プログラマーを目指す人なら、index.html に 2934a685527f5cd6bcb20a3dc28499e1 の行を追加したくないでしょう?また、UI内のすべての文章は画像を使用した生徒に帰属します。立ち上がって退出してください。 React プロジェクトのどこかから何かをエレガントにインポートし、インターフェイス内のテキストを 0cffce67d2f17d9dbaff4b78ee2046fc コンポーネントに置き換え、最終的に簡単な設定で言語の国際化を実現したい場合は、React -intl を使用します。
React の国際化には、React-intl を使用することをお勧めします。このライブラリは、日付、数値、文字列などをフォーマットするための React コンポーネントと API を提供します。このライブラリについて理解したので、使用してみましょう
コンポーネントの使用法
React とさらに統合するには、コンポーネントを使用します
1. 参照を追加します
npm install react-intl --save3. ロケール設定ファイルを追加します
zh-CN.js
import {IntlProvider, addLocaleData} from 'react-intl';en-US.js
const zh_CN = { 'intl.hello': "你好", 'intl.name': '我的名字是 {name}' } export default zh_CN;4. 1905fd125854d59ec1f7dec72e3298cfを使用します
i18n コンテキストを使用すると、アプリケーション全体が i18n のコンテキストで設定されるように、アプリケーションのルート コンポーネントがラップされます。 2 つの最も重要な設定項目は次のとおりです。 現在のロケール メッセージと現在の言語のコンテンツを読み込みます。
const en_US = { 'intl.hello': "hello", 'intl.name': 'my name is {name}' } export default en_US;
基本的な使い方
import zhCN from './locale/zh.js'; //导入 i18n 配置文件 import enUS from './locale/en.js'; addLocaleData([...en, ...zh]); export default class Root extends Component { static propTypes = { store: PropTypes.object.isRequired, history: PropTypes.object.isRequired } render() { const { store , history } = this.props; return ( <IntlProvider locale='zh' messages={zhCN}> <Provider store={store}> <Router history={history}> </Router> </Provider> </IntlProvider> ) } }
動的値の受け渡し
<FormattedMessage id="intl.hello" defaultMessage={'hello'} />
6. 他のコンポーネントの使用法
<FormattedMessage id="intl.name" values={{name: <b>{name}</b>}} />
2. コンポーネントにインジェクトします
import { injectIntl, FormattedMessage } from 'react-intl';
プロジェクトではReduxを使用しました。 Redux では、デフォルトの injectIntl(App) をエクスポートするだけです
3. intl オブジェクトを使用します
PHP - 自動多言語切り替えの実装
ASP.NET Core の多言語についてサポートの詳細な紹介
以上がReact-intl実装の多言語例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。