关于进出场动画
进出场动画,最早我实在Angular中接触到的。Angular中简单的配置,就可实现页面有动画的卸载和动画记载,令我影响深刻。但是在react中,并没找到直接的进出场动画。调研了一下,这个具体实现,要借助官方的一个组件来实现。
演示
这个效果是基于iOS系统设置列表选择列表项的效果制作的,但是返回效果没能实现iOS一样的倒退效果。
ReactCSSTransitionGroup
这个组件是 react-addons-css-transition-group 这个库中的组件。这个库也是官方推荐的React拓展库。这个库暂时不多做介绍,详细请看比如 react ReactCSSTransitionGroup 动画api
这里使用的是ReactCSSTransitionGroup组件配合React-Router完成的效果。
原理
这个动画完成的原理主要有两个:
ReactCSSTransitionGroup 组件通过给children添加配置的class,通过css过渡动画,实现进场和出厂动画。当children发生变化时,通过判定children组件的key。如果key相同,则不发生变化;key不同,则判定其是挂载还是卸载,来添加对应的css类。
React-Router 就是常用的前端路由。通过匹配路由表中的路由,切换不同的组件。并且可以给组件注入页面路由等参数。