React 国際化 react-i18next の詳細な説明

React 国際化 react-i18next の詳細な説明

ここに画像の説明を挿入

導入

react-i18next は、 i18nextをベースにした強力な国際化フレームワークです。 reactおよびreact-nativeアプリケーションで使用できます。 現在、非常に主流の国際化ソリューションです。

i18nextには次の利点があります。

  • i18next をベースにしているので react に限らず、一度学んで他の場所でも使えます。
  • hoc、フック、クラスのシナリオで国際化のための複数のコンポーネントを提供します
  • サーバーサイドレンダリングに適しています
  • 2011 年に開始された長い歴史があり、ほとんどのフロントエンド フレームワークよりも古いものです。
  • 長い歴史があるため、より成熟しており、i18next が解決できない国際化の問題はありません。
  • 多くのプラグインがサポートされており、例えば、プラグインを使用して現在のシステムのロケールを検出し、サーバーまたはファイルシステムから翻訳リソースを読み込むことができます。

インストール

i18nextreact-i18next両方の依存関係をインストールする必要があります。

npm install react-i18next i18next --save
または
yarn add react-i18next i18next --save


構成

国際化関連の設定を保存するために、 srcの下に新しいi18nフォルダを作成します。

i18nに 3 つの新しいファイルを作成します。

  • config.ts : i18n を初期化し、プラグインを構成する
  • en.json : 英語言語設定ファイル
  • zh.json : 中国語言語設定ファイル

ここに画像の説明を挿入

ja.js で

{
    「ヘッダー」: {
        "登録":"登録",
        "signin":"サインイン",
        "ホーム": "ホーム"
    },
    「フッター」: {
        「詳細」: 「React のすべての権利は留保されています」
    },
    "家": {
        "hot_recommended": "ホットなおすすめ",
        "new_arrival": "新着",
        "joint_venture": "ジョイントベンチャー"
    }
}

.js は、

{
    「ヘッダー」: {
        "登録":"登録",
        "signin":"ログイン",
        "ホーム": "ホーム"
    },
    「フッター」: {
        「詳細」: 「著作権 @ React」
    },
    "家": {
        "hot_recommended": "ホットなおすすめ",
        "new_arrival": "新着",
        "joint_venture": "ジョイントベンチャー"
    }
}

config.ts

'i18next' から i18n をインポートします。
'react-i18next' から { initReactI18next } をインポートします。

'./en.json' から translation_en をインポートします。
'./zh.json' から translation_zh をインポートします。

定数リソース = {
    ja: 翻訳:
        翻訳: translation_en,
    },
    ja: {
        翻訳: translation_zh,
    },
};

i18n.use(initReactI18next).init({
    リソース、
    長さ: 'zh',
    補間:
        エスケープ値: false、
    },
});

デフォルトの i18n をエクスポートします。

使用

参照プロファイル

index.tsx内のi18n構成ファイルを参照します: import './i18n/config';

'react' から React をインポートします。
'react-dom' から ReactDOM をインポートします。
'./index.css' をインポートします。
'./App' から App をインポートします。
import './i18n/config'; // 設定ファイルを参照 ReactDOM.render(
    <React.StrictMode>
        <アプリ />
    </React.StrictMode>,
    ドキュメント.getElementById('ルート')
);

コンポーネントでの使用

方法1

クラスコンポーネントwithTranslation高階関数(HOC)を使用して、言語構成のデータ注入を完了します。

'react' から React をインポートします。
'./Home.module.css' からスタイルをインポートします。

//HOC高階関数withTranslationとi18n ts型定義WithTranslationを導入する 
「react-i18next」から{withTranslation, WithTranslation}をインポートします。

クラス HomeComponent は React.Component<WithTranslation> を拡張します {
    与える() {
        定数 t は、 this.props に代入されます。
        戻る <>
           <h1>{t('header.home')}</h1>
           <ul>
               <li>{t('home.hot_recommended')}</li>
               <li>{t('home.new_arrival')}</li>
               <li>{t('home.joint_venture')}</li>
           </ul>
        </>
    }
}

export const Home = withTranslation()(HomeComponent); // withTranslation高階関数を使用して言語設定のデータ注入を完了します

方法2

関数コンポーネントuseTranslationフックを使用して国際化を処理する

'react' から React をインポートします。
'react-i18next' から {useTranslation, Trans} をインポートします。

エクスポートconstホーム: React.FC = () => {
    const { t } = useTranslation()
    戻る (
		<div>
			<h1>{t('header.home')}</h1>
			<ul>
				<li>{t('home.hot_recommended')}</li>
				もう一つの方法があります */
				<li><Trans>home.new_arrival</Trans></li>
			</ul>
		</div>    
    );
};

言語を切り替える

'i18next' から i18n をインポートします。

定数changeLanguage= (val) => {
	i18n.changeLanguage(val); // valパラメータの値は'en'または'zh'です
};

または

'react' から React をインポートします。
'react-i18next' から {useTranslation} をインポートします。

エクスポートconstホーム: React.FC = () => {
    const { t, i18n } = useTranslation()
    戻る (
		<button onClick={()=>i18n.changeLanguage(i18n.language=='en'?'zh':'en')}>{i18n.language=='en'?'zh':'en'}</button>
    );
};

React 国際化 react-i18next に関するこの記事はこれで終わりです。React 国際化 react-i18next に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • react-intlはReactの国際化と多言語化メソッドを実装します
  • reactの国際化のためのプラグインであるreact-i18n-autoの使い方の詳細な説明
  • React 国際化実装コード例

<<:  純粋なCSSで立体的な画像配置効果を実現するサンプルコード

>>:  Nginx+tomcat ロードバランシングクラスタの実装方法

推薦する

vscode dockerプラグインのdocker.socket権限問題を解決する

解決策: システム内のすべての .vscode 関連プロセスを終了します (または、remote-s...

単一行関数と文字計算日付プロセス制御を説明する MySQL の例

目次1. キャラクター機能1. ケースコントロール機能2. キャラクターコントロール機能2. 数学関...

ナビゲーションバーのドロップダウンメニューのサンプルコードを実装するためのHTML+CSS

効果コード内の画像は自分で変更できますドロップダウンメニューのHTMLコード <ヘッダークラ​...

さまざまなMySQLインデックスの使用方法の詳細な説明

1. 遅いクエリログ1.1 MySQL ログの種類ログは、データベースの操作や、ユーザーがデータベー...

表に斜めヘッダー効果を出す5つの方法

誰もがテーブルをよく知っているはずです。コード内でよく見かけます。テーブルにスラッシュ ヘッダーを追...

Linux システムのシャットダウンコマンドの違いと使い方の詳細な説明

Linux システムのシャットダウン コマンドは何ですか? Liangxu Tutorial Net...

MySQLとRedisでセカンダリキャッシュを実装する方法の詳細な説明

Redis の紹介Redis は完全にオープンソースで無料であり、BSD プロトコルに準拠しており、...

Prometheusコンテナのデプロイメントのための実用的なソリューション

環境ホスト名IPアドレス仕えるプロメテウス192.168.237.137プロメテウス、グラファナノー...

HTML テーブルタグチュートリアル (11): 水平方向の配置属性 ALIGN

水平方向では、テーブルの配置を左、中央、右に設定できます。基本的な構文<テーブル配置=&quo...

mybatis-plusページングパラメータが渡された後、SQLのwhere条件にはページング情報操作の制限がありません

2時間近くかけて、さまざまな方法を試しました。後で、whereでフィルタリングした後のデータ量が1ペ...

MySql データベース クエリの特殊コマンド

まずMySQLのインストールMySQLソフトウェアをダウンロードし、インストールパスを変更しますMy...

CSSの優先度を理解する2つの方法

方法1: 値を追加する公式の説明を見るには MDN にアクセスしてください。優先度はどのように計算さ...

MySQLで最大接続数を達成する方法

目次データベース接続数が急増した理由は何ですか? 1. はじめに2. 知識ポイント3. 練習するIV...

リンク更新ページと js 更新ページの使用例

1. リンクの使用方法:コードをコピーコードは次のとおりです。 <a href="j...

ホストがアクセスできるようにMySQLの権限を変更する方法

mysqlのリモートアクセス権を有効にするデフォルトでは、MySQL ユーザーにはリモート アクセス...