0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

MS FluentUI DetailsList Tips

Posted at

FluentUI DetailsList Tips

FluentUIのDetailsListに役立ちそうなコードを載せていきます。

1.クリックでアイテムを選択した際に、すでに選択したアイテムが解除されないようにする

Detailsリストのセルをクリックすることで選択することができるのですが、チェックボタン以外の部分をクリックしてしまうとすでに選択したアイテムが解除されてしまいます。

解決方法

selectionオブジェクトを作成し、setModal関数にtrueをセットしてDetailsListに渡すと、セルのどの部分をクリックしても選択したアイテムが解除されないようになります。

const selection = new Selection()
selection.setModal(true);

const MyGrid = () => {

    return(
        <DetailsList items={items} columns={columns} selectionMode={2} selection={selection}/>
    );
}

2.上下キーで移動した際に選択したアイテムが変更されないようにする

解決方法

ISelectionZoneProps型のオブジェクトを作成し、isSelectedOnFocusにfalseを、selectionにDetailsListに渡したものと同じselectionを渡します。
これをDetailsListのselectionZonePropsにセットします。
これで上下キーでフォーカスを移動してもアイテムの選択状況は変更されないようになります。

const selection = new Selection()
selection.setModal(true);

const MyGrid = () => {

    return(
        <DetailsList items={items} columns={columns} selectionMode={2} selection={selection} 
        selectionZoneProps={{isSelectedOnFocus:false, selection:selection}}/>
    );
}
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?