零经验学 react 的第15天 - 过渡动画(使用 react-transition-group 库进行实现)

一、安装依赖:react-transition-group

reactcommunity.org/react-trans...

bash 复制代码
npm install react-transition-group

二、过渡动画实现示例

jsx

jsx 复制代码
import { CSSTransition } from 'react-transition-group';
import React, { useRef } from 'react';
import './index.css';


function Transition1() {
    const [show, setShow] = React.useState(true);
    const timeout = 3000
    const nodeRef = useRef(null);
    
    return (
        <div>
            <h2>过渡动画</h2>
            <div className="btn-group" style={{ display: 'flex', gap: '10px', justifyContent: 'center', cursor: 'pointer' }}>
                <p onClick={() => setShow(true)} style={show ? { color: 'red' } : {}}>显示</p>
                <p onClick={() => setShow(false)} style={!show ? { color: 'red' } : {}}>隐藏</p>
            </div>


            {/*
                1、nodeRef方式使用CSSTransition:
                - 通过nodeRef属性传入ref对象,来避免findDOMNode的使用,从而避免在严格模式下出现警告。
                - 需要注意的是,使用nodeRef时,必须确保ref对象正确地引用了要应用过渡效果的DOM节点。
                - 另外,nodeRef方式不支持某些过渡效果,如appear效果。
            */}


            {/*
                2、classNames、in、timeout
                - classNames 属性指定了过渡效果的类名前缀,这些类名会在不同的过渡阶段自动添加到元素上,从而实现动画效果。
                - 通过 in 属性控制过渡效果的触发,当 in 为 true 时,元素进入过渡状态;当 in 为 false 时,元素离开过渡状态。
                - timeout 属性指定了过渡效果的持续时间,单位为毫秒。
            */}

            <CSSTransition nodeRef={nodeRef} classNames="div-box" in={show} timeout={timeout}>
                <div ref={nodeRef} className="div-box">
                <h3>内容</h3>
                </div>
            </CSSTransition>
        </div>
    );
}

export default Transition1;

css

css 复制代码
.div-box {
    transition: opacity 3s;
}

/* 显示 */
.div-box-enter {
    display: block;
    opacity: 0;
}

.div-box-enter-active {
    display: block;
    opacity: 0.5;
}

.div-box-enter-done {
    display: block;
    opacity: 1;
}


/* 隐藏 */
.div-box-exit {
    display: block;
    opacity: 1;
}

.div-box-exit-active {
    display: block;
    opacity: 0.5;
}

.div-box-exit-done {
    display: none;
    opacity: 0;
}
相关推荐
SuperEugene2 小时前
Vue3 + Element Plus 表单开发实战:防重复提交、校验、重置、loading 统一|表单与表格规范篇
前端·javascript·vue.js
SuperEugene2 小时前
Vue3 + Element Plus 中后台弹窗规范:开闭、传参、回调,告别弹窗地狱|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
桜吹雪2 小时前
在前端运行Qwen3.5原生多模态模型
前端·人工智能·机器学习
孟祥_成都2 小时前
前端下午茶:这 3 个网页特效建议收藏(送源码)
前端·javascript·css
SuperEugene2 小时前
VXE-Table 4.x 实战规范:列配置 + 合并单元格 + 虚拟滚动,避坑卡顿 / 错乱 / 合并失效|表单与表格规范篇
开发语言·前端·javascript·vue.js·前端框架·vxetable
火车叼位2 小时前
Volta 下 `corepack` 失踪之谜:问题不在 Node,而在命令入口
前端
cmd2 小时前
别再用错!5种JS类型判断方法,从原理到实战一文吃透
前端·javascript
小江的记录本2 小时前
【Redis】Redis常用命令速查表(完整版)
java·前端·数据库·redis·后端·spring·缓存
Csvn2 小时前
状态管理方案对比(Context、Zustand、Jotai 选型指南)
前端