如何使用React实现动效弹窗组件(react,开发技术)

时间:2024-05-02 19:18:41 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

本文小编为大家详细介绍“如何使用React实现动效弹窗组件”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何使用React实现动效弹窗组件”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

1. 没有动效的弹窗

在 React 中,可以这样来实现:

interfaceModalProps{open:boolean;onClose?:()=>void;children?:any;}constModal=({open.onClose,children}:ModalProps)=>{if(!open){returnnull;}returncreatePortal(<div><divclassname="modal-content">{children}</div><divclassname="modal-close-btn"onclick="{onClose}">x</div></div>,document.body);};

使用方式:

constApp=()=>{const[open,setOpen]=useState(false);return(<divclassname="app"><buttononclick="{()"=="">setOpen(true)}>showmodal</button><modalopen="{open}"onclose="{()"=="">setOpen(false)}>modalcontent</modal></div>);};

我们在这里就是使用open属性来控制展示还是不展示,但完全没有渐变的效果。

若我们想实现 fade, zoom 等动画效果,还需要对此进行改造。

2. 自己动手实现有动效的弹窗

很多同学在自己实现动效时,经常是展示的时候有动效,关闭的时候没有动效。都是动效的时机没有控制好。这里我们先自己来实现一下动效的流转。

刚开始我实现的时候,动效只有开始状态和结束状态,需要很多的变量和逻辑来控制这个动效。

后来我参考了react-transition-group组件的实现,他是将动效拆分成了几个部分,每个部分分别进行控制。

  1. 展开动效的顺序:enter -> enter-active -> enter-done;

  2. 关闭动效的顺序:exit -> exit-active -> exit-done;

动效过程在enter-activeexit-active的过程中。

我们再通过一个变量 active 来控制是关闭动效是否已执行关闭,参数 open 只控制是执行展开动效还是关闭动效。

当 open 和 active 都为 false 时,才销毁弹窗。

constModal=({open,children,onClose})=>{const[active,setActive]=useState(false);//弹窗的存在周期if(!open&&!active){returnnull;}returnReactDOM.createPortal(<divclassname="modal"><divclassname="modal-content">{children}</div><divclassname="modal-close-btn"onclick="{onClose}">x</div></div>,document.body,);};

这里我们接着添加动效过程的变化:

const[aniClassName,setAniClassName]=useState('');//动效的class//transition执行完毕的监听函数constonTransitionEnd=()=>{//当open为rue时,则结束状态为'enter-done'//当open未false时,则结束状态为'exit-done'setAniClassName(open?'enter-done':'exit-done');//若open为false,则动画结束时,弹窗的生命周期结束if(!open){setActive(false);}};useEffect(()=>{if(open){setActive(true);setAniClassName('enter');//setTimeout用来切换class,让transition动起来setTimeout(()=>{setAniClassName('enter-active');});}else{setAniClassName('exit');setTimeout(()=>{setAniClassName('exit-active');});}},[open]);

Modal 组件完整的代码如下:

constModal=({open,children,onClose})=>{const[active,setActive]=useState(false);//弹窗的存在周期const[aniClassName,setAniClassName]=useState('');//动效的classconstonTransitionEnd=()=>{setAniClassName(open?'enter-done':'exit-done');if(!open){setActive(false);}};useEffect(()=>{if(open){setActive(true);setAniClassName('enter');setTimeout(()=>{setAniClassName('enter-active');});}else{setAniClassName('exit');setTimeout(()=>{setAniClassName('exit-active');});}},[open]);if(!open&&!active){returnnull;}returnReactDOM.createPortal(<divclassname="{'modal"'=""+=""aniclassname}=""ontransitionend="{onTransitionEnd}"><divclassname="modal-content">{children}</div><divclassname="modal-close-btn"onclick="{onClose}">x</div></div>,document.body,);};

动效的流转过程已经实现了,样式也要一起写上。比如我们要实现渐隐渐现的 fade 效果:

.enter{opacity:0;}.enter-active{transition:opacity200msease-in-out;opacity:1;}.enter-done{opacity:1;}.exit{opacity:1;}.exit-active{opacity:0;transition:opacity200msease-in-out;}.exit-done{opacity:0;}

如果是要实现放大缩小的 zoom 效果,修改这几个 class 就行。

一个带有动效的弹窗就已经实现了。

使用方式:

constApp=()=>{const[open,setOpen]=useState(false);return(<divclassname="app"><buttononclick="{()"=="">setOpen(true)}>showmodal</button><modalopen="{open}"onclose="{()"=="">setOpen(false)}>modalcontent</modal></div>);};

3. react-transition-group

我们在实现动效的思路上借鉴了 react-transition-group 中的CSSTransition组件。CSSTransition已经帮我封装好了动效展开和关闭的过程,我们在实现弹窗时,可以直接使用该组件。

这里有一个重要的属性:unmountOnExit,表示在动效结束后,卸载该组件。

constModal=({open,onClose})=>{//http://reactcommunity.org/react-transition-group/css-transition///in属性为true/false,true为展开动效,false为关闭动效returncreatePortal(<csstransitionin="{open}"timeout="{200}"unmountonexit=""><divclassname="modal"><divclassname="modal-content">{children}</div><divclassname="modal-close-btn"onclick="{onClose}">x</div></div></csstransition>,document.body,);};

在使用 CSSTransition 组件后,Modal 的动效就方便多了。

如何使用React实现动效弹窗组件

读到这里,这篇“如何使用React实现动效弹窗组件”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

本文:如何使用React实现动效弹窗组件的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Ref在React中怎么交叉使用下一篇:

11 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18