React Tree Grid 検索フィルター
React Tree Grid の Ignite UI for React 検索フィルター機能を使用すると、データのコレクション内の値を検索するプロセスが可能になります。この機能のセットアップが簡単になり、検索入力ボックス、ボタン、キーボード ナビゲーション、その他の便利な機能を使用して実装できるため、ユーザー エクスペリエンスがさらに向上します。ブラウザーにはネイティブなコンテンツ検索機能がありますが、ほとんどの場合で IgrTreeGrid は表示範囲外の行列を仮想化します。そのため、ネイティブ ブラウザー検索は DOM の一部でないため仮想化セルでデータを検索できません。IgrTreeGrid では、React Material テーブル ベースのグリッドの拡張により、検索 API を使用した仮想コンテンツの検索が可能です。
React 検索の例
次の例は、すべての列と行を検索できる検索入力ボックスと、各列の特定のフィルタリング オプションを備えた IgrTreeGrid を表しています。
React 検索の使用
Tree Grid のセットアップ
グリッドを作成してからデータをバインドします。コンポーネントにカスタム スタイルも追加しました。
<IgrTreeGrid ref={gridRef} data={data} autoGenerate={false} primaryKey="ID" foreignKey="ParentID" allowFiltering={true} height="100%" width="100%">
<IgrColumn field="Name" dataType="string" sortable={true}></IgrColumn>
<IgrColumn field="ID" dataType="number" sortable={true}></IgrColumn>
<IgrColumn field="Title" dataType="string" sortable={true}></IgrColumn>
<IgrColumn field="Age" dataType="number" sortable={true}></IgrColumn>
<IgrColumn field="HireDate" dataType="date" sortable={true}></IgrColumn>
</IgrTreeGrid>
では、IgrTreeGrid の検索 API の準備をしましょう。検索したテキストの保存、また大文字小文字の区別や完全一致 (またはそのいずれか) に使用するプロパティを作成できます。
const gridRef = useRef<IgrTreeGrid>(null);
const [caseSensitiveSelected, setCaseSensitiveSelected] = useState<boolean>(false);
const [exactMatchSelected, setExactMatchSelected] = useState<boolean>(false);
const [searchText, setSearchText] = useState('');
React 検索ボックス入力
検索入力を作成します。searchText を新しく作成したinput要素の value プロパティにバインドし、inputOccured イベントをサブスクライブすることで、ユーザーによるすべての searchText の変更を検出できます。これにより、IgrTreeGrid の findNext メソッドと findPrev メソッドを使用して、searchText が出現するすべての箇所をハイライト表示し、(呼び出したメソッドに応じて) 次 / 前の箇所にスクロールできるようになります。
FindNext と FindPrev メソッドの両方に 3 つの引数があります。
Text: string (検索テキスト)- (オプション)
CaseSensitive: boolean (検索で完全一致するかどうか、デフォルト値は false)。 - (オプション)
ExactMatch: boolean (検索で完全一致するかどうか、デフォルト値は false)。
完全一致で検索した場合、検索 API は SearchText と完全一致 (大文字小文字の区別を含む) するセル値のみ結果としてハイライト表示します。たとえば、文字列 ‘software’ と ‘Software’ は大文字小文字を区別しない場合は完全一致となります。
上記のメソッドは number 値を返します (IgrTreeGrid で指定した文字列が含まれる回数)。
const handleOnSearchChange = (event: IgrComponentValueChangedEventArgs) => {
setSearchText(event.detail);
nextSearch(event.detail, caseSensitiveSelected, exactMatchSelected);
}
<IgrInput name="searchBox" value={searchText} onInput={handleOnSearchChange}>
</IgrInput>
検索ボタンの追加
ボタンの各クリック イベント ハンドラー内で FindNext と FindPrev メソッドを呼び出して検索や検索結果をナビゲーションするためのボタンを作成します。
<IgbIconButton Variant="IconButtonVariant.Flat" @onclick="PrevSearch">
<IgbIcon IconName="prev" Collection="material"/>
</IgbIconButton>
<IgbIconButton Variant="IconButtonVariant.Flat" @onclick="NextSearch">
<IgbIcon IconName="next" Collection="material" />
</IgbIconButton>
@code {
private IgbGrid grid;
public void PrevSearch()
{
this.grid.FindPrevAsync(this.searchText, this.caseSensitive, this.exactMatch);
}
public void NextSearch()
{
this.grid.FindNextAsync(this.searchText, this.caseSensitive, this.exactMatch);
}
}
キーボード検索の追加
ユーザーは矢印キーと ENTER キーで結果を移動できます。PreventDefault メソッドのデフォルト キャレットの移動を防止する検索入力の keydown イベントを処理し、ユーザーが押したキーに基づいて FindNext/FindPrev メソッドを呼び出します。
const searchKeyDown = (e: KeyboardEvent<HTMLElement>) => {
if (e.key === 'Enter' || e.key === 'ArrowDown') {
e.preventDefault();
nextSearch(searchText, caseSensitiveSelected, exactMatchSelected);
} else if (e.key === 'ArrowUp') {
e.preventDefault();
prevSearch(searchText, caseSensitiveSelected, exactMatchSelected);
}
}
const handleOnSearchChange = (event: IgrComponentValueChangedEventArgs) => {
setSearchText(event.detail);
gridRef.current.findNext(event.detail, caseSensitiveSelected, exactMatchSelected);
}
<div onKeyDown={searchKeyDown}>
<IgrInput name="searchBox" value={searchText} onInput={handleOnSearchChange}></IgrInput>
</div>
大文字と小文字の区別と完全一致
次に完全一致の検索で大文字と小文字を区別するかどうかをユーザーが選択できるようにします。この目的のために、単純な選択可能な Chips を使用し、igcSelect イベントにバインドして、ユーザーがいつチップを操作したかを判断できます。
constructor() {
const case = document.getElementById("case") as HTMLInputElement;
const exact = document.getElementById("exact") as HTMLInputElement;
case.addEventListener("change", this.updateSearch);
exact.addEventListener("change", this.updateSearch);
}
public updateSearch() {
const search1 = document.getElementById("search1") as HTMLInputElement;
const case = document.getElementById("case") as HTMLInputElement;
const exact = document.getElementById("exact") as HTMLInputElement;
const grid = document.getElementById("grid") as IgcGridComponent;
grid.findNext(search1.value, case.checked, exact.checked);
}
保持
IgrTreeGrid のフィルターやソート、レコードの追加や削除をする場合を想定します。そのような処理の後、現在の検索が自動的に更新されて SearchText に一致するテキストが保持されます。更に検索がページングで動作し、IgrTreeGrid の PerPage プロパティの変更時もハイライト表示が保持されます。
アイコンの追加
その他のコンポーネントを使用するためにユーザー インターフェイスを作成し、検索バー全体のデザインを向上します。検索入力の左側に検索または削除アイコン、検索オプションのチップ、右側にはマテリアル デザイン アイコンと Ripple スタイルのボタンを組み合わせたナビゲーションを表示できます。
IgrInput 内のすべてのコンポーネントをラップします。左側で検索と 削除/クリア アイコンを切り替えます (検索入力が空かどうかに基づきます)。中央に入力を配置します。更に削除アイコンがクリックされたときに SearchText を更新し、IgrTreeGrid.findNext の ClearSearch メソッドを呼び出してハイライト表示をクリアします。
右側の入力グループに以下の目的で別のコンテナーを作成します。
- 検索結果の表示
public showResults() {
if (this.grid.lastSearchInfo.matchInfoCache.length > 0) {
var index = this.grid.lastSearchInfo.activeMatchIndex + 1 ;
var length = this.grid.lastSearchInfo.matchInfoCache.length;
document.getElementById('results').innerHTML = index +'of' + length + 'results';
}
else if (this.grid.lastSearchInfo.matchInfoCache.length == 0) {
document.getElementById('results').innerHTML = 'No results';
}
}
- 検索ナビゲーションボタンには、マテリアル アイコン付きのリップル スタイル ボタンを追加しています。click イベントのハンドラーはそのままで
FindNext/FindPrevメソッドを呼び出します。
<div class="chips">
<igx-chips-area>
<igx-chip (click)="updateSearch()" [color]="caseSensitive? 'lightgrey' : 'rgba(0, 0, 0, .04)'">
<span>Case Sensitive</span>
</igx-chip>
<igx-chip (click)="updateExactSearch()" [color]="exactMatch? 'lightgrey' : 'rgba(0, 0, 0, .04)'">
<span>Exact Match</span>
</igx-chip>
</igx-chips-area>
</div>
次に、入力の左側に検索アイコンとクリア アイコンを追加します。
<div slot="suffix">
<igc-chip selectable="true" id="caseSensitiveChip">Case Sensitive</igc-chip>
<igc-chip selectable="true" id="exactMatchChip">Exact Match</igc-chip>
</div>
既知の問題と制限
| 制限 | 説明 |
|---|---|
| テンプレートを使用したセル内の検索 | 検索機能のハイライト表示が、デフォルトのセルテンプレートに対してのみ機能する問題。カスタム セル テンプレートを含む列がある場合、ハイライト表示が機能しないため、列フォーマッタなどの代替アプローチを使用するか、Searchable (検索可能な) プロパティを false に設定します。 |
| リモート仮想化 | リモート仮想化の使用時に検索が正しく動作しません。 |
| セル テキストが切れる問題 | セル内のテキストが長すぎるために検索テキストが省略記号によって切れている場合も、セルまでスクロールして一致カウントに含まれますが、ハイライト表示はされません。 |
API リファレンス
IgrTreeGrid
IgrColumn
その他のリソース
コミュニティに参加して新しいアイデアをご提案ください。