Upgrade to Pro — share decks privately, control downloads, hide ads and more …

React 19でつくる「気持ちいいUI」- 楽観的UIのすすめ

React 19でつくる「気持ちいいUI」- 楽観的UIのすすめ

BuriKaigi 2026

Avatar for Hiroshi Morishige

Hiroshi Morishige

January 09, 2026
Tweet

More Decks by Hiroshi Morishige

Other Decks in Programming

Transcript

  1. 森茂 洋 (Hiroshi Morishige) クラスメソッド株式会社 製造ビジネステクノロジー部 テクニカルリードエンジニア 今日お話しすること 1. 優しい嘘

    - 楽観的UIの概念 2. 仕組みと効果 - なぜ必要か 3. React 19 - 実装パターン 4. Artificial Delay - 楽観の逆 5. まとめ - 引き出しとして
  2. かつての実装は「根性」だった • 複雑な手動の状態管理 • 地獄のようなエラー処理 • バグが起きやすい境界条件 React 19で useOptimistic

    フックが登場。 この「魔法」を正式な仕組みにした。 楽観的UIは「新しい魔法」じゃない 新しいフックの登場 • 即時UI更新 • 失敗時の自動ロールバック • 型安全
  3. 実装パターン 1. useState サーバーと同期する「本来の状態」管理 2. useOptimistic UIに即時表示するための「仮の状態」を生成 3. startTransition この中でAPIを呼び出すReactが処理中であること

    を把握 4. 自動ロールバック startTransition内の非同期処理が失敗すると、 Reactが自動でoptimisticTodosを元のtodos の状態に戻してくれる
  4. 私たちの仕事は、処理を速くすることではなく、 応答時間を「期待値」に合わせること 楽観的UI (Optimistic) 意図的遅延 (Artificial Delay) ユーザーの期待 「即座に反応してほしい」 「しっかり処理してほしい」

    目的 遅い処理を速く見せる 速い処理を適切に見せる 適用例 いいね、チャット、並び替え AI分析、セキュリティ確認、審査 使い分けの鍵は「ユーザーの期待」に合わせ ること
  5. 付録 : 用語解説と出典 用語 概要 出典 楽観的UI (Optimistic UI) 非同期処理の完了を待たずにUIを先行更新

    し、失敗時にロールバックする手法 React公式ドキュメント Labor Illusion 処理の「労力」を可視化することでユーザーの 満足度・信頼度が向上する現象 Buell & Norton, Harvard Business School (2011) Artificial Delay ユーザーの期待に合わせて意図的に遅延を 加えるUXテクニック UXデザインの一般的手法 Operational Transparency 内部プロセスや労力を顧客に見せることで価 値認知を高める概念 Buell & Norton, Harvard Business School (2011)
  6. 付録 : 参考文献・リンク集 公式ドキュメント • React useOptimistic https://react.dev/reference/react/useOptimistic • Smashing

    Magazine - 楽観的UIの解説 https://www.smashingmagazine.com/2016/11/true-lies-of-optimistic-user-interfaces/ • The Behavioral Scientist - Labor Illusion https://www.thebehavioralscientist.com/glossary/labor-illusion • CursorUp - Labour Illusionの実践ガイド https://www.cursorup.com/blog/labour-illusion 解説記事 • Labor Illusion 論文 Buell, R. W., & Norton, M. I. (2011). "The Labor Illusion: How Operational Transparency Increases Perceived Value" 学術論文