React动态效果——animate.css

1.React引入Animate.css
  • animate官网
    animate官网查看需要的动效

  • react项目引入animate.css

npm i animate.css
npm i react-addons-css-transition-group

  • 封装react动效木偶组件
import React from 'react'
import "animate.css";
import ReactCSSTransitionGroup from "react-addons-css-transition-group";
class Transition extends React.Component {

    constructor(props){
        super(props);
        this.state = {}
    }

    render(){
        return(
            <div>
                <ReactCSSTransitionGroup
                    transitionEnter={true}
                    transitionLeave={true}
                    transitionEnterTimeout={2500}
                    transitionLeaveTimeout={1500}
                    transitionName="animated"
                >
                    {this.props.children}
                </ReactCSSTransitionGroup>
            </div>
        )
    }
}
export default Transition;
  • 调用Tansition木偶组件
state = {
        transition:"lightSpeedIn",
        icon:"icon-mulu"
    }

hanldleMenu = ()=>{
        this.setState({
            icon:'icon-mulu'=== this.state.icon ? 'icon-guanbi':'icon-mulu',
            transition:'rotateIn' === this.state.transition ? 'lightSpeedIn' : 'rotateIn'
        })
    }
 render(){
        return(
		<Transition>
	    <div onClick={this.hanldleMenu}
	         style={{width:20}}
	         key="amache"
	         className={`animated ${this.state.transition}`}>
	        <i className={`iconfont ${this.state.icon}`} style={{fontSize:20}}/>
	    </div>
	</Transition>
	)}

animate.css官网中的class类名,修改state中的transition

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果你想在路由切换时使用 animate.css 的过渡动效,你可以结合一些前端框架(如Vue.js、React等)以及路由库(如Vue Router、React Router等)来实现。 下面以 Vue.js 和 Vue Router 为例,演示如何在路由切换时动态添加 animate.css 的效果: 1. 首先,确保你已经引入了 Vue.js、Vue Router 和 animate.css 的文件。 2. 在 Vue 组件中,可以使用 Vue Router 提供的导航守卫来监听路由切换事件。在路由切换开始前,我们可以为要切换的元素添加 animate.css 的动画效果类,然后在切换完成后移除该类。 ```javascript // 在 Vue 组件中的路由守卫中添加动画效果 export default { // ... beforeRouteLeave(to, from, next) { // 为要切换的元素添加 animate.css 的动画效果类 document.getElementById('yourElementId').classList.add('animate__animated', 'animate__fadeOut'); // 使用 setTimeout 设定一个适当的延迟时间,确保动画效果完成后再进行路由切换 setTimeout(() => { next(); }, 1000); // 假设动画效果需要 1 秒钟 }, // ... } ``` 在上述代码中,我们在 `beforeRouteLeave` 导航守卫中监听路由切换事件。在此之前,你需要给要切换的元素添加一个唯一的 id,然后通过 `getElementById` 获取该元素,并使用 `classList.add` 方法为其添加 animate.css 的动画效果类。 3. 在 CSS 文件中引入 animate.css,并定义相应的动画效果类。 ```css @import url('animate.min.css'); .animate__fadeOut { animation-duration: 1s; /* 动画持续时间 */ } ``` 在上面的例子中,我们使用了 animate.css 提供的 `animate__fadeOut` 类,表示淡出效果。你可以根据 animate.css 的文档选择其他的动画效果类。 通过以上步骤,你就可以在路由切换时动态添加 animate.css 的过渡动效了。请注意,这只是一个简单的示例,并且需要根据具体的项目结构和需求进行适当的修改和调整。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乐闻x

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值