antd的tabs组件切换动画异常

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Ant Design提供了一个动画组件 `CSSTransition`,可以用来实现组件切换动画效果。 使用步骤如下: 1. 安装依赖 ```bash npm install react-transition-group --save ``` 2. 引入组件 ```js import { CSSTransition } from 'react-transition-group'; import 'animate.css/animate.min.css'; // 引入动画库 ``` 3. 定义动画 CSS 类 在 `animate.css` 中选择一个适合的动画效果,例如 `fadeIn`。然后定义一个新的 CSS 类,如下所示: ```css .fadeIn-enter { opacity: 0; } .fadeIn-enter-active { opacity: 1; transition: opacity 500ms ease-in; } .fadeIn-exit { opacity: 1; } .fadeIn-exit-active { opacity: 0; transition: opacity 500ms ease-out; } ``` 这里定义了四个 CSS 类,分别是: - `.fadeIn-enter`:组件进入前的状态 - `.fadeIn-enter-active`:组件进入过程中的状态 - `.fadeIn-exit`:组件离开前的状态 - `.fadeIn-exit-active`:组件离开过程中的状态 4. 使用组件 将要动画切换组件包裹在 `CSSTransition` 组件中,设置 `classNames` 和 `timeout` 属性。`classNames` 属性值为刚才定义的动画 CSS 类名,`timeout` 属性值为动画持续时间。 例如: ```jsx <CSSTransition classNames="fadeIn" timeout={500} > {showComponent ? <ComponentA /> : <ComponentB />} </CSSTransition> ``` 这里定义了一个切换动画效果为 `fadeIn`,持续时间为 500 毫秒。`showComponent` 为 true 时展示 `ComponentA`,为 false 时展示 `ComponentB`。 完整代码示例: ```jsx import React, { useState } from 'react'; import { CSSTransition } from 'react-transition-group'; import 'animate.css/animate.min.css'; const FadeInComponent = () => { const [showComponent, setShowComponent] = useState(true); const toggleShowComponent = () => { setShowComponent(!showComponent); }; return ( <div> <button onClick={toggleShowComponent}>切换组件</button> <CSSTransition classNames="fadeIn" timeout={500} > {showComponent ? <div>ComponentA</div> : <div>ComponentB</div>} </CSSTransition> </div> ); }; export default FadeInComponent; ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值