Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
複雑なコンポーネントで 状態をもつのをやめた話 PrAha x Resily 勉強会 vol.1 Daisuke Mino
Slide 2
Slide 2 text
複雑なコンポーネント構成での お話です
Slide 3
Slide 3 text
状態、 どこにもたせてますか?
Slide 4
Slide 4 text
Objectの中? data = [{ id: 1, visible: true, }, { id: 2, visible: false, }]
Slide 5
Slide 5 text
やばい(やばい)
Slide 6
Slide 6 text
やばいポイント1 例えば `isDragging` , `isHover` , `isScrolling` のような、ユーザー入力 によって状態が目まぐるしく変わるような状態を、複雑なコンポーネントを操作 する場合においては、状態を操作した場所が追いづらくなる。 コンポーネントに閉じる状態ならばコンポーネント内のstateに閉じておけばよ いが、渡されたデータの状態フィールドに変更を加えつつ他のコンポーネント に伝達する場合を想定する。
Slide 7
Slide 7 text
やばいポイント2 状態の変更がどのコンポーネントに影響を与えるのか、詳細にコードを見てい かないと分からない。
Slide 8
Slide 8 text
やばいポイント3 コンポーネントのレンダリングをメモ化する際に、与えられたデータの等価性を 比較する際に全フィールドを検査する必要がある。
Slide 9
Slide 9 text
データはデータ 状態は状態 で保持する
Slide 10
Slide 10 text
状態用のリストに状態を保持する data = [{ id: 1, }, { id: 2, }] invisibleIds = [2]
Slide 11
Slide 11 text
やばくないポイント1 状態リストを操作したコードを調べていくと、どこでどのような操作がされたの か明確。
Slide 12
Slide 12 text
やばくないポイント2 どのコンポーネントがどの状態を参照しているか明確になった。
Slide 13
Slide 13 text
やばくないポイント3 メモ化されたコンポーネントを返すかどうかの判定において、データを舐める必 要がなく、状態のIDリストの内容だけを比較したらよい。
Slide 14
Slide 14 text
状態の他にも、 構造も別で保持する
Slide 15
Slide 15 text
状態 ● selectedGroupIds: Set ● selectedUserIds: Set ● focusedIds: Set ● invalidIds: Set ● disabledIds: Set ● intersectingIds: Set
Slide 16
Slide 16 text
構造 ● idNode: Map ● parentChildren: Map> ● childParent: Map ● parentDescendants: Map> ● childAncestors: Map> ● rects: Map
Slide 17
Slide 17 text
ただし、 複雑じゃないコンポーネント構 成では、オブジェクトに持たせ るのが明快そう
Slide 18
Slide 18 text
おわり