React Grid 高度なフィルタリング

    React Grid の Ignite UI for React 高度なフィルタリングを使用すると、IgrGrid のすべての列にわたるフィルタリング条件を使用してさまざまなグループを作成できるダイアログが表示されるため、データを操作できます。

    React Grid 高度なフィルタリングの例

    EXAMPLE
    TSX
    CSS

    このサンプルが気に入りましたか? 完全な Ignite UI for Reactツールキットにアクセスして、すばやく独自のアプリの作成を開始します。無料でダウンロードできます。

    インタラクション

    高度なフィルタリングダイアログを開くには、グリッドツールバーの [高度なフィルタリング] ボタンをクリックする必要があります。高度なフィルターが適用されていない場合、AND または OR でリンクされたフィルター条件のグループの作成から開始する必要があります。その後、フィルタリング条件またはサブグループを追加できます。

    フィルター条件を追加するには、filterable 列のいずれか、dataType 列に基づくオペランド、およびオペランドが単項でない場合の値を選択する必要があります。条件が確定すると、条件情報を含むチップが表示されます。チップをホバーまたはクリックすると、チップを変更したり、その直後に別の条件やグループを追加したりできます。

    複数のフィルター条件チップを選択すると、グループを作成したりフィルターを削除したりするためのオプションを含むコンテキストメニューが表示されます。選択した条件でグループを作成することを選択した場合、一番上に選択した条件が配置された場所に新しく作成されたグループが表示されます。

    グループを選択するために、リンク条件 (AND または OR) に基づいて色付けされた垂直線をクリックすることもできます。単一のグループが選択されている場合、フィルタリング ロジックを変更、グループ解除、または削除するオプションを含むコンテキスト メニューが表示されます。

    フィルタリング条件とグループを作成する準備後にデータをフィルタリングするには、[適用] ボタンをクリックします。拡張フィルターを変更後、変更を保存したくない場合は、[キャンセル] ボタンをクリックします。[フィルターのクリア] ボタンをクリックして、高度なフィルターをクリアすることもできます。

    Ignite UI for React | CTA Banner

    使用方法

    高度なフィルタリングを有効にするには、allowAdvancedFiltering 入力プロパティを true に設定します。

    <IgrGrid data={nwindData} autoGenerate={false} ref={gridRef} allowAdvancedFiltering={true}>
        <IgrGridToolbar></IgrGridToolbar>
    </IgrGrid>
    tsx

    高度なフィルタリングは、advancedFilteringExpressionsTree 入力プロパティに保存される filteringExpressionsTree を生成します。advancedFilteringExpressionsTree プロパティを使用して、高度なフィルタリングの初期状態を設定できます。

    const filteringTree: IgrFilteringExpressionsTree = {
        operator: FilteringLogic.And,
        filteringOperands: [
            {
                fieldName: "ProductID",
                condition: new IgrNumberFilteringOperand().condition("doesNotEqual"),
                searchVal: 1,
                ignoreCase: true,
            },
            {
                fieldName: "ProductName",
                conditionName: "startsWith",
                searchVal: "Ch",
                ignoreCase: true,
            }
        ]
    };
    
    <IgrGrid data={data} allowFiltering={true} advancedFilteringExpressionsTree={filteringTree}>
        <IgrGridToolbar>
            <IgrGridToolbarActions>
                <IgrGridToolbarAdvancedFiltering></IgrGridToolbarAdvancedFiltering>
            </IgrGridToolbarActions>
        </IgrGridToolbar>
        <IgrColumn field="ProductID" filterable={true} dataType="number"></IgrColumn>
        <IgrColumn field="ProductName" dataType="string" filterable={true}></IgrColumn>
    </IgrGrid>
    tsx

    IgrGrid ツールバーを表示したくない場合は、openAdvancedFilteringDialog および closeAdvancedFilteringDialog メソッドを使用して、高度なフィルタリング ダイアログをコーディングを使用して開いたり閉じたりできます。

    IgrGrid で QuickFilter/ExcelStyleFilter と高度なフィルタリング ユーザー インターフェイスの両方を有効にできます。両フィルタリング ユーザー インターフェイスは、互いに依存せずに機能します。IgrGrid の最終的なフィルター結果は、2 つのフィルター結果の共通部分です。

    スタイル設定

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

    <IgrGrid className="grid"></IgrGrid>
    tsx

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

    .grid {
        --ig-grid-filtering-row-background: #ffcd0f;
        --ig-grid-filtering-background-or: #d83434;
    }
    css

    デモ

    EXAMPLE
    TSX
    CSS

    API リファレンス

    その他のリソース

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