Close
Angular React Web Components Blazor
Premium

React Tree Grid 複数列ヘッダーの概要

React Tree Grid の Ignite UI for React 複数列ヘッダー機能は、共通の複数ヘッダーの下に配置することで列をグループ化できます。IgrTreeGrid の各複数ヘッダー グループは、その他のグループや列を組み合わせて表示できます。この機能は、水平方向のスクロールが面倒な大規模なデータセットを扱う場合に特に役立ちます。

React Tree Grid 複数列ヘッダーの例

複数列ヘッダーの宣言は、一連の列を IgrColumnGroup コンポーネントにラップし、Header タイトル情報を渡すことによって実現されます。

<IgrTreeGrid primaryKey="ID" foreignKey="ParentID">
    <IgrColumnGroup header="Contact Information">
        <IgrColumn sortable={true} resizable={true} field="Phone" dataType="string"></IgrColumn>
        <IgrColumn sortable={true} resizable={true} field="Fax" dataType="string"></IgrColumn>
        <IgrColumn sortable={true} resizable={true} field="PostalCode" dataType="string"></IgrColumn>
    </IgrColumnGroup>
</IgrTreeGrid>

ネストしたヘッダーの n-th レベルは、上記の宣言に従います。したがって、IgrColumnGroup をネストすることで、望ましい結果が得られます。

<IgrTreeGrid primaryKey="ID" foreignKey="ParentID" moving={true}>
    <IgrColumnGroup pinned={false} header="General Information">
        <IgrColumn field="HireDate" sortable={true} resizable={true} dataType="date"></IgrColumn>
        <IgrColumnGroup header="Person Details">
            <IgrColumn field="ID" resizable={true} filterable={true} dataType="number"></IgrColumn>
            <IgrColumn field="Title" sortable={true} resizable={true} dataType="string"></IgrColumn>
            <IgrColumn field="Age" sortable={true} resizable={true} dataType="number"></IgrColumn>
        </IgrColumnGroup>
    </IgrColumnGroup>
</IgrTreeGrid>

すべての IgrColumnGroup は、移動ピン固定、および非表示をサポートしています。

列セットと列グループがある場合、ピン固定は列の一番上の親レベルでのみ可能です。具体的には、ネストされた column groups または columns ごとのピン固定は許可されていません。
columns と column groups 間の移動は、それらが階層内の同じレベルにあり、両方が同じ group にある場合にのみ許可されます。
columns/column-groups が現在の group によってラップされていない場合 (一番上のレベル columns の場合)、表示されている列全体の間で移動が許可されます。

<IgrTreeGrid primaryKey="ID" foreignKey="ParentID" moving={true}>
    <IgrColumnGroup header="Contact Information">
        <IgrColumn field="Phone" movable={true} sortable={true} resizable={true} dataType="string"></IgrColumn>
    </IgrColumnGroup>
    <IgrColumn field="Name" sortable={true} resizable={true} dataType="string"></IgrColumn>
    <IgrColumn field="Title" sortable={true} resizable={true} dataType="string"></IgrColumn>
    <IgrColumn field="Age" sortable={true} resizable={true} dataType="number"></IgrColumn>
</IgrTreeGrid>

複数列ヘッダー テンプレート

<IgrColumnGroup header="Contact Information" headerTemplate={groupHeaderTemplate}></IgrColumnGroup>
const groupHeaderTemplate = (e: IgrColumnTemplateContext) => {
  const column = e.column as IgrColumnGroup;
    return (
      <div>
        <span style={{ float: "left" }}>{column.header.toUpperCase()}</span>
      </div>
    );
}

ヘッダーが再テンプレート化され、対応する列グループが移動可能な場合は、テンプレート要素で draggable 属性を false に設定する必要があり、これにより適用されるイベントをすべて処理できます。

const columnHeaderTemplate = (e: IgrColumnTemplateContext ) => {
  const column = e.column as IgrColumnGroup;
    return (
      <span onClick={onClick}>
        <IgrIcon data-draggable="false"></IgrIcon>
      </span>
    );
}

次のサンプルは、ヘッダー テンプレートを使用して折りたたみ可能な列グループを実装する方法を示しています。

スタイル設定

定義済みのテーマに加えて、利用可能な CSS プロパティのいくつかを設定することで、グリッドをさらにカスタマイズできます。 一部の色を変更したい場合は、最初にグリッドのクラスを設定する必要があります。

<IgrTreeGrid className="grid"></IgrTreeGrid>

次に、そのクラスに関連する CSS プロパティを設定します。

<IgrTreeGrid class="grid"></IgrTreeGrid>

デモ

API リファレンス

IgrTreeGrid
IgrColumn
IgrColumnGroup

その他のリソース

コミュニティに参加して新しいアイデアをご提案ください。