零经验学 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;
}
相关推荐
weelinking几秒前
【claude】14_Claude作为技术文档助手
前端·人工智能·react.js·数据挖掘·前端框架
jiayong236 分钟前
前端面试题库 - JavaScript核心基础篇
前端·javascript·面试
软件技术NINI20 分钟前
泉州html+css 4页
前端·javascript·css·html
再吃一根胡萝卜21 分钟前
OpenScreen:免费开源的录屏神器,做出专业级演示视频
前端
Cloud_Shy61822 分钟前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 下篇)
前端·后端·python·数据分析·excel
kyriewen24 分钟前
我用AI把公司10万行代码屎山重构了,CTO看了代码后说:你提前转正
前端·javascript·ai编程
ttwuai26 分钟前
XYGo Admin 菜单与路由:Vue3 动态路由 + GoFrame 权限菜单的完整实现方案
前端·vue·后台框架
程序员码歌35 分钟前
OpenSpec 到 Superpowers:AI 编码从说清到做对
android·前端·人工智能
爱编程的小新☆35 分钟前
LangGraph4j工作流框架
前端·数据库·ai·langchain·langgraph4j