Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Speaker Deck
PRO
Sign in
Sign up for free
Reactアニメーション事始め
takanorip
May 27, 2017
0
650
Reactアニメーション事始め
takanorip
May 27, 2017
Tweet
Share
More Decks by takanorip
See All by takanorip
ソフトウェアエンジニアの教養を養う本
takanorip
1
13k
共創するためのデザイン批評
takanorip
7
3.2k
Figmaプラグイン 開発のすゝめ
takanorip
0
170
Headless Components Design
takanorip
0
39
10分で理解する HTML Modules
takanorip
1
390
Polymer Project 2020
takanorip
1
120
技術とデザインの間
takanorip
0
1.3k
Color in Interface Experience
takanorip
1
89
ウェブフォント今昔物語
takanorip
5
3.6k
Featured
See All Featured
Designing the Hi-DPI Web
ddemaree
272
32k
Teambox: Starting and Learning
jrom
121
7.6k
The Illustrated Children's Guide to Kubernetes
chrisshort
14
34k
GraphQLとの向き合い方2022年版
quramy
16
8.1k
jQuery: Nuts, Bolts and Bling
dougneiner
56
6.4k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
237
19k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
11
4.6k
Fashionably flexible responsive web design (full day workshop)
malarkey
396
62k
The Invisible Side of Design
smashingmag
289
48k
Learning to Love Humans: Emotional Interface Design
aarron
261
37k
The Power of CSS Pseudo Elements
geoffreycrofte
46
3.9k
Designing on Purpose - Digital PM Summit 2013
jponch
106
5.6k
Transcript
React アニメーション事始め Takanori Oki 第1回 React.js 導入事例 @ 弥生
目次 • 自己紹介 • 導入 • 主要な実装方とポイント • まとめ
自己紹介
自己紹介 • 大木尊紀( @takanorip ) • フロントエンドエンジニア (ウェブサイト制作とか) • 株式会社スマートドライブ(2017.06.01~)
• 最近の悩み:体重の増加
Reactでアニメーション
要件・きもち
要件・きもち • 実装したいもの • リスト追加、削除時のアニメーション • メニューの開閉など • きもち •
シンプルに実装したい
普通のアニメーション • CSSアニメーション (transition、keyframesなど) • jQuery、velocity.jsなどのライブラリを使用 • DOMをゴリゴリいじる感じのやつ
Reactのつらみ
つらみ • jQuery使えない • DOM参照つらい • DOMをいじるのはVirtualDOM経由
実装方法 1. stateを更新する方法 2. react-transition-group 3. ライブラリを使用
stateを更新する方法
stateを更新する方法 • stateを更新してマルチクラスの付け替え • メニューの開閉などウェブサイトでよくある 動きを実装する時使える • React v15.0からDOMのCSSAnimationEvent をトリガーできるようになった
Actionを検知 state更新 アニメーション classを付け替え Actionを検知 class付け替え アニメーション jQueryとか React
要素の追加、削除は苦手 • アニメーションが終わってから要素を削除し ないといけない • 自前で実装するのは難しい
削除イベント発火 アニメーション開始 アニメーション終了 DOM削除 DOM追加 アニメーション開始 アニメーション終了 この間DOMは 残しておく必要 あり
react-transition-group
react-transition-group • 公式のアドオン • CSSTransitionGroupとTransitionGroup • 以前はReactTransitionGroupと ReactCSSTransitionGroupがあったが、 React v15.5.0で非推奨になってしまった
(使い方などは特に変わらない)
CSSTransitionGroup <CSSTransitionGroup transitionName="example" transitionEnterTimeout={500} transitionLeaveTimeout={300}> {items} </CSSTransitionGroup>
CSSTransitionGroup • CSSアニメーションさせるときに使う • コンポーネントの追加、削除時にclassを 付与する • 簡単にアニメーションできる • ロジック管理できない
ライブラリを使用
ライブラリを使用 • CSSより複雑な動き表現できる • アニメーションのロジックを管理できる • シンプルに使うことができる
主なライブラリ • react-motion • velocity-react • react-animations • react-tween-state
ライブラリについて詳しくは こちらの記事を参照! Reactのアニメーションを 攻略する
応用編
応用編 • Reduxを使ってアニメーションのロジックを 管理する • 複雑なアニメーションもできる • アニメーションをDOMから分離できるので、 TweenMaxなど通常使用しているライブラリ を使うこともできるようになる
まとめ • Reactとアニメーションは相性悪いけどやりよ うはたくさんある • ライブラリはそれぞれできることが違うので 確認必要 • もっと複雑なアニメーションを実装する時は Redux使って実装する