React Tabs (タブ) の概要

    React タブは軽量で使いやすいコンポーネントで、対応するコンテンツをタブ形式または通常は水平に配置されたタブのコレクションで整理します。React タブを使用すると、エンドユーザーは簡単にクリックしてさまざまなビューを表示できます。タブの向き、テンプレート、組み込みのヘッダー スタイル、アニメーション、スクロール ボタンなど、いくつかの機能とカスタマイズ オプションがあります。

    Ignite UI for React タブは、同様のデータ セットを整理して切り替えます。タブは、データ コンテンツの上部に配置されます。タブが選択されると、対応する ID を持つパネルが表示されます。このコンポーネントは、定義されたタブのみ (パネルなし) で使用できます。

    React タブの例

    以下の React タブの例では、3 つの異なるタブが 1 行に並んで表示されているため、それぞれをすばやく簡単に移動できます。

    Ignite UI for React でタブを使用する方法

    まず、次のコマンドを実行して、対応する Ignite UI for React npm パッケージをインストールする必要があります:

    npm install igniteui-react
    

    IgrTabs を使用する前に、次のように登録する必要があります:

    import { IgrTabsModule, IgrTabs, IgrTab,  IgrTabPanel} from "igniteui-react";
    
    IgrTabsModule.register();
    

    Ignite UI for React の完全な概要については、作業の開始トピックを参照してください。

    単純な IgrTabs の宣言は次のように行われます:

    <IgrTabs>
        <IgrTab panel="first">Tab 1</IgrTab>
        <IgrTab panel="second">Tab 2</IgrTab>
        <IgrTab panel="third">Tab 3</IgrTab>
        <IgrTabPanel id="first">Panel 1</IgrTabPanel>
        <IgrTabPanel id="second">Panel 2</IgrTabPanel>
        <IgrTabPanel id="third">Panel 3</IgrTabPanel>
    </IgrTabs>
    

    選択

    ユーザーがキーを押すかクリックして項目を選択すると、IgrTabsChange イベントを発行します。select メソッドを使用すると、パネルを文字列値として指定してタブを選択できます。

    選択したタブが初期の読み込み時に指定されていない場合、無効になっていない最初のタブが選択されます。

    ユーザーが矢印キーでナビゲートしているときにタブを選択するデフォルトの動作は、activation プロパティによって変更できます。Manual に設定すると、矢印キーを押すと次 / 前のタブにフォーカスしますが、タブは Space または Enter を押した後にのみ選択されます。

    無効化されたタブ

    disabled 属性を設定すると、タブが無効になります:

    <IgrTab panel="first" disabled={true}>Tab 1</IgrTab>
    

    配置

    alignment プロパティは、React タブの配置方法を制御します。プロパティは以下の値を含みます:

    • Start (デフォルト): タブの幅はコンテンツ (ラベル、アイコン、両方) に依存し、すべてのタブのパディングは等しくなります。最初のタブは、タブ コンテナーの左側に配置されます。
    • Center: タブの幅はコンテンツによって異なり、タブ コンテナーの中心を占めます。
    • End: タブの幅はコンテンツによって異なり、すべてのタブのパディングは同じです。最後のタブは、タブ コンテナーの右側に配置されます。
    • Justify: すべてのタブは幅が等しく、タブ コンテナーに完全に収まります。

    スペースがすべてのタブに収まらない場合は、スクロール ボタンが表示されます。

    スクローリング

    スクロール ボタンは、利用可能なスペースがすべての React タブを描画するのに十分でない場合に表示されます。最初のタブが表示されている場合、スクロール開始ボタンは無効になります。最後のタブが表示されている場合、スクロール終了ボタンは無効になります。スクロール ボタンの 1 つを押すと、その方向のタブが完全に表示されるようにタブがスクロールされます。または、既に表示されている場合は、その方向の前 / 次のタブが表示されます。

    キーボード ナビゲーション

    キー 説明
    前 (右から左モードでは次) のタブを選択します。activationManual に設定されている場合は、タブのみがフォーカスされます。最初のタブにある場合は最後までスクロールします。
    次へ (右から左モードでは前へ) タブを選択します。activationManual に設定されている場合は、タブのみがフォーカスされます。最後のタブにある場合は、スクロールして開始します。
    Home 最初のタブを選択します。
    End 最後のタブを選択します。
    Enter / Space activationManual の場合、フォーカスされたタブを選択します。

    Prefix / Suffix (プレフィックス / サフィックス)

    各タブには、情報を表示するためのデフォルト スロットがあります。アイコン、テキスト、またはその両方と、開始および / または終了に追加のコンテンツを表示するための prefixsuffix のスロットです。

    スタイル設定

    IgrTabs コンポーネントは、そのすべての要素の CSS パーツを公開します。

    名前 説明
    headers タブとスクロール ボタンを含むラッパー。
    headers-content タブの描画に使用できるスペースを表すタブのコンテナー。
    headers-wrapper タブと選択されたインジケーターのラッパー。
    headers-scroll タブのコンテナー。
    selected-indicator 選択されたインジケーター。
    start-scroll-button タブがオーバーフローしたときに表示されるスクロール開始ボタン。
    end-scroll-button タブがオーバーフローしたときに表示されるスクロール終了ボタン。
    content データが表示されるコンテンツのコンテナー。

    IgrTab コンポーネントは、次の CSS パーツを公開します:

    名前 説明
    base タブ ヘッダーの基本ラッパー。
    prefix プレフィックス ラッパー。
    suffix サフィックス ラッパー。
    igc-tabs::part(selected-indicator) {
        background: #ecaa53;
    }
    
    igc-tab::part(base) {
        background: #ffe6cc;
    }
    

    API リファレンス

    その他のリソース