时间:2021-05-25
问题
在单页面应用中,我们经常需要给路由的切换或者元素的挂载和卸载加上过渡效果,为这么一个小功能引入第三方框架,实在有点小纠结。不如自己封装。
思路
原理
以进入时 opacity: 0 --> opacity: 1 ,退出时 opacity: 0 --> opacity: 1 为例
元素挂载时
1.挂载元素dom
2.设置动画 opacity: 0 --> opacity: 1
元素卸载时
1.设置动画 opacity: 0 --> opacity: 1
2.动画结束后卸载dom
组件设计
为了使得组件简单易用、低耦合,我们期望如下方式来调用组件:
属性名 类型 描述 isShow Boolean 子元素显示或隐藏控制 name String 指定一个name,动画进入退出时的动画
在 App.jsx 里调用组件:
通过改变isShow的值来指定是否显示
// App.jsx// 其他代码省略import './app.css';<Animation isShow={isShow} name='demo'> <div class='demo'> demo </div></Animation>// 通过改变isShow的值来指定是否显示在 App.css 里指定进入离开效果:// 基础样式.demo { width: 200px; height: 200px; background-color: red;}// 定义进出入动画.demo-showing { animation: show 0.5s forwards;}.demo-fading { animation: fade 0.5s forwards;}// 定义动画fade与show@keyframes show { from { opacity: 0; } to { opacity: 1; }}@keyframes fade { from { opacity: 1; } to { opacity: 0; }}根据思路写代码
// Animation.jsximport { PureComponent } from 'react';import './index.css';class Animation extends PureComponent { constructor(props) { super(props); this.state = { isInnerShow: false, animationClass: '', }; } componentWillReceiveProps(props) { const { isShow } = props; if (isShow) { // 显示 this.show().then(() => { this.doShowAnimation(); }); } else { // 隐藏 this.doFadeAnimation(); } } handleAnimationEnd() { const isFading = this.state.animationClass === this.className('fading'); if (isFading) { this.hide(); } } show() { return new Promise(resolve => { this.setState( { isInnerShow: true, }, () => { resolve(); } ); }); } hide() { this.setState({ isInnerShow: false, }); } doShowAnimation() { this.setState({ animationClass: this.className('showing'), }); } doFadeAnimation() { this.setState({ animationClass: this.className('fading'), }); } /** * 获取className * @param {string} inner 'showing' | 'fading' */ className(inner) { const { name } = this.props; if (!name) throw new Error('animation name must be assigned'); return `${name}-${inner}`; } render() { let { children } = this.props; children = React.Children.only(children); const { isInnerShow, animationClass } = this.state; const element = { ...children, props: { ...children.props, className: `${children.props.className} ${animationClass}`, onAnimationEnd: this.handleAnimationEnd.bind(this), }, }; return isInnerShow && element; }}export default Animation;Demo示例
点我直达
总结
以上所述是小编给大家介绍的在React中写一个Animation组件为组件进入和离开加上动画/过度效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近重读Vue官方文档,在列表的排序过渡这一小节,文档提到,组件有一个特殊的地方,不仅可以实现进入和离开动画,还可以改变定位,官网示例如下:例子中实现的效果看起
React组件的this是什么通过编写一个简单组件,并渲染出来,分别打印出自定义函数和render中的this:importReactfrom'react';c
在上一节中,我们讲到了React组件,说了如何使用ES6类创建一个React组件并在其他的地方使用它。这一节我们将讲到React组件的两大灵魂——props和s
在react组件中,每个方法的上下文都会指向该组件的实例,即自动绑定this为当前组件,而且react还会对这种引用进行缓存,以达到cpu和内存的最大化。在使用
关于react与vue中的key之前在学习react的时候,常常遇到循环渲染组件时会提示需要在循环组件中加上key属性,比如有一组列表:importReact,