React 之 过渡动画

这篇具有很好参考价值的文章主要介绍了React 之 过渡动画。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

React 之 过渡动画,React,css,前端,html,Powered by 金山文档

一、React的过渡动画

  • 在开发中,我们想要给一个组件的显示和消失添加某种过渡动画,可以很好的增加用户体验

  • 可以通过原生的CSS来实现这些过渡动画,但是React社区为我们提供了react-transition-group用来完成过渡动画

  • React曾为开发者提供过动画插件 react-addons-css-transition-group,后由社区维护,形成了现在的 react-transition-group

这个库可以帮助我们方便的实现组件的 入场 和 离场 动画,使用时需要进行额外的安装

1. 安装

npm install react-transition-group --save
react-transition-group本身非常小,不会为应用程序增加过多的负担

2. 主要组件

  • Transition

  • 该组件是一个和平台无关的组件(不一定要结合CSS);

  • 在前端开发中,一般是结合CSS来完成样式,所以比较常用的是CSSTransition

  • CSSTransition

  • 在前端开发中,通常使用CSSTransition来完成过渡动画效果

  • 如果只有一个组件,直接使用这个即可

  • SwitchTransition

  • 两个组件显示和隐藏切换时,使用该组件

  • TransitionGroup

  • 将多个动画组件包裹在其中,一般用于列表中元素的动画

二、CSSTransition

1. 概念

CSSTransition是基于Transition组件构建的
CSSTransition执行过程中,有三个状态:appear、enter、exit;

它们有三种状态,需要定义对应的CSS样式:

  • 第一类,开始状态:

  • 对于的类是-appear、-enter、-exit

  • 第二类:执行动画:

  • 对应的类是-appear-active、-enter-active、-exit-active

  • 第三类:执行结束:

  • 对应的类是-appear-done、-enter-done、-exit-done;

2. 常见属性

in:触发进入或者退出状态

  • 如果添加了unmountOnExit={true},那么该组件会在执行退出动画结束后被移除掉

  • 当in为true时,触发进入状态,会添加-enter、-enter-acitve的class开始执行动画

  • 当动画执行结束后,会移除两个class,并且添加-enter-done的class

  • 当in为false时,触发退出状态,会添加-exit、-exit-active的class开始执行动画

  • 当动画执行结束后,会移除两个class,并且添加-enter-done的class;

classNames:动画class的名称

决定了在编写css时,对应的class名称:比如card-enter、card-enter-active、card-enter-done

timeout:过渡动画的时间

appear:是否在初次进入添加动画(需要和in同时为true)

unmountOnExit:退出后卸载组件

其他属性

3. 对应的钩子函数

主要为了检测动画的执行过程,来完成一些JavaScript的操作
  • onEnter:在进入动画之前被触发

  • onEntering:在应用进入动画时被触发

  • onEntered:在应用进入动画结束后被触发

  • onExit:离开动画之前被触发

  • onExiting:离开动画时被触发

  • onExited:离开动画之后被触发

4. 简单使用

组件

import React, { PureComponent } from 'react';
// 1. 导入动画组件
import { CSSTransition } from 'react-transition-group';
// 2. 导入动画样式
import './style.css';

export class App extends PureComponent {
  constructor() {
    super();
    this.state = {
      isShow: true
    };
  }
  render() {
    const { isShow } = this.state;
    return (
      <>
        <button onClick={(e) => this.setState({ isShow: !isShow })}>切换</button>
        {/* 
          in: 控制动画的状态
          timeout: 动画执行的时间
          classNames: 动画的类名前缀
          unmountOnExit: 动画退场时,移除dom
          appear: 初次加载时,是否执行动画
          onEnter: 开始进入动画
          onEntering: 执行进入动画
          onEntered: 进入动画结束
          onExit: 开始离开动画
          onExiting: 正在离开动画
          onExited: 离开动画结束
        */}
        <CSSTransition
          in={isShow}
          unmountOnExit={true}
          classNames='coder'
          timeout={2000}
          appear
          onEnter={(e) => console.log('开始进入动画')}
          onEntering={(e) => console.log('执行进入动画')}
          onEntered={(e) => console.log('进入动画结束')}
          onExit={(e) => console.log('开始离开动画')}
          onExiting={(e) => console.log('正在离开动画')}
          onExited={(e) => console.log('离开动画结束')}>
          <h2>APP</h2>
        </CSSTransition>
      </>
    );
  }
}

export default App;

样式

/* 第一次加载时显示 */
.coder-appear{
  transform: translateX(-200px);
}
.coder-appear-active{
  transform: translateX(0);
  transition: all 2s ease-in;
}

/* 进入动画 */
.coder-enter{
  opacity: 0;
}
.coder-enter-active{
    opacity: 1;
    transition: all 2s ease-in;
}

/* 退出动画 */
.coder-exit{
  opacity: 1;
}
.coder-exit-active{
  opacity: 0;
  transition: all 2s ease-in;
}

效果

React 之 过渡动画,React,css,前端,html,Powered by 金山文档

5. 问题

在严格模式下,使用可能会报错,因为CSSTransition还在使用之前过期的API => findDOMNode

解决方式一 : 关闭严格模式

解决方式二 : 改变源码

解决方式三 : 设置ref

import React, { Fragment, PureComponent, createRef } from 'react';
import { CSSTransition } from 'react-transition-group';
import './style.css';

export class App extends PureComponent {
  constructor() {
    super();
    this.state = {
      isShow: true
    };
    // 1. 创建ref对象
    this.titleRef = createRef();
  }
  render() {
    const { isShow } = this.state;
    return (
      <Fragment>
        <button onClick={(e) => this.setState({ isShow: !isShow })}>切换</button>
        {/* 
          nodeRef: 用于指定动画的DOM节点
        */}
        <CSSTransition
          // 3. 绑定这个ref对象
          nodeRef={this.titleRef}
          in={isShow}
          unmountOnExit={true}
          classNames='coder'
          timeout={2000}
          appear
          onEnter={(e) => console.log('开始进入动画')}
          onEntering={(e) => console.log('执行进入动画')}
          onEntered={(e) => console.log('进入动画结束')}
          onExit={(e) => console.log('开始离开动画')}
          onExiting={(e) => console.log('正在离开动画')}
          onExited={(e) => console.log('离开动画结束')}>
          {/* 2. 绑定这个ref对象 */}
          <h2 className='title' ref={this.titleRef}>
            APP
          </h2>
        </CSSTransition>
      </Fragment>
    );
  }
}

export default App;

三、SwitchTransition

SwitchTransition可以完成两个组件之间切换的炫酷动画:
  • 比如有一个按钮需要在on和off之间切换,希望看到on先从左侧退出,off再从右侧进入

  • 这个动画在vue中被称之为 vue transition modes

  • react-transition-group中使用SwitchTransition来实现该动画

SwitchTransition中主要有一个属性:mode,有两个值
  • in-out:表示新组件先进入,旧组件再移除

  • out-in:表示就组件先移除,新组件再进入

SwitchTransition的使用
  • SwitchTransition组件里面要有CSSTransition或者Transition组件,不能直接包裹想要切换的组件

  • SwitchTransition里面的CSSTransition或Transition组件不再像以前那样接受in属性来判断元素是何种状态,取而代之的是key属性

  • key必须要指定两个不同的值,用来判定是否切换文章来源地址https://www.toymoban.com/news/detail-534320.html

代码

import React, { Fragment, PureComponent, createRef } from 'react';
import { SwitchTransition, CSSTransition } from 'react-transition-group';
import './style.css';

export class App extends PureComponent {
  constructor() {
    super();
    this.state = {
      isShow: true
    };
    this.titleRef = createRef();
  }
  render() {
    const { isShow } = this.state;
    return (
      <Fragment>
        <button onClick={(e) => this.setState({ isShow: !isShow })}>切换</button>
        {/* 
          out-in: 新元素先执行进入动画,动画执行完毕后,旧元素执行离开动画
          in-out: 旧元素先执行离开动画,动画执行完毕后,新元素执行进入动画
        */}
        <SwitchTransition mode='out-in'>
          <CSSTransition
            // 必须有可以更改的key值
            key={isShow ? 'coder' : 'star'}
            nodeRef={this.titleRef}
            unmountOnExit={true}
            classNames='coder'
            timeout={2000}
            onEnter={(e) => console.log('开始进入动画')}
            onEntering={(e) => console.log('执行进入动画')}
            onEntered={(e) => console.log('进入动画结束')}
            onExit={(e) => console.log('开始离开动画')}
            onExiting={(e) => console.log('正在离开动画')}
            onExited={(e) => console.log('离开动画结束')}>
            <h2 className='title' ref={this.titleRef}>
              <span>{isShow ? 'coder' : 'star'}</span>
            </h2>
          </CSSTransition>
        </SwitchTransition>
      </Fragment>
    );
  }
}

export default App;

效果

React 之 过渡动画,React,css,前端,html,Powered by 金山文档

四、TransitionGroup

当有一组动画时,需要将这些CSSTransition放入到一个TransitionGroup中来完成动画

样式

/* 第一次加载时显示 */
.book-appear{
  transform: translateX(-200px);
}
.book-appear-active{
  transform: translateX(0);
  transition: all 1s ease-in;
}

/* 进入动画 */
.book-enter{
  transform: translateX(100px);
  opacity: 0;
}
.book-enter-active{
  transform: translateX(0);
  opacity: 1;
  transition: all 1s ease-in;
}

/* 退出动画 */
.book-exit{
  opacity: 1;
  transform: translateX(0);

}
.book-exit-active{
  opacity: 0;
  transform: translateX(-100px);
  transition: all 1s ease-in;
}

组件

import React, { PureComponent } from 'react';
import { TransitionGroup, CSSTransition } from 'react-transition-group';
import './style.css';
export class App extends PureComponent {
  constructor() {
    super();
    this.state = {
      books: [
        { name: 'React', id: 1 },
        { name: 'Vue', id: 2 },
        { name: 'Angular', id: 3 }
      ]
    };
  }
  // 增加数据
  addBooks() {
    const books = [...this.state.books];
    books.push({
      name: 'JavaScript高级程序设计',
      id: new Date().getTime()
    });
    this.setState({ books });
  }
  // 删除数据
  deleteBooks(index) {
    const books = [...this.state.books];
    books.splice(index, 1);
    this.setState({ books });
  }
  render() {
    const { books } = this.state;
    /**
     * component 属性指定过渡组件的类型,默认是div
     * key 属性是必须唯一,如果使用index作为key,会出现删除数据时,动画效果不对的问题
     */
    return (
      <div>
        <TransitionGroup component='ul'>
          {books.map((item, index) => {
            return (
              <CSSTransition key={item.id} appear classNames='book' timeout={1000}>
                <li>
                  <span>{item.name}</span>
                  <button onClick={(e) => this.deleteBooks(index)}>删除</button>
                </li>
              </CSSTransition>
            );
          })}
        </TransitionGroup>
        <button onClick={(e) => this.addBooks()}>增加数据</button>
      </div>
    );
  }
}

export default App;

效果

React 之 过渡动画,React,css,前端,html,Powered by 金山文档

到了这里,关于React 之 过渡动画的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【CSS】过渡动画

    不加过渡动画,变化不太流畅 MDN css transitions w3school transform transform :用于元素的变形,显示变形后的状态,不是变形的过程,变形过程需要配合 transition 表示 2D 转换 translate(50px, 100px) 平移 rotate(20deg) 顺时针旋转 20 度 rotateX(150deg) 绕其 X 轴旋转给定角度 scaleX(2) 增大为其原始

    2024年02月04日
    浏览(33)
  • CSS基础-过渡动画

    CSS3新添加了过渡动画, 即使用者定义好 一个元素的 开始状态 和 结束状态 , CSS会根据变化曲线形成 补间动画 效果。 CSS3中用 transition 属性来描述动画如何运动。 定义 下面我们重点了解下, 哪个属性需要过渡 , 还有 变化曲线是什么 下面我们重点聊聊两点: 哪个属性需要

    2024年02月10日
    浏览(43)
  • css3过渡与动画

    在数字时代,网页不再是静态的画面,而是充满活力和动感的空间。CSS3的过渡与动画技术就像是一场魔法表演,能够赋予网页以生命。本文将引领你进入这个奇妙的世界,解锁CSS3过渡与动画的神奇效果。 transition过渡属性时css3浓墨重彩的特性,过渡可以为一个元素在不同样

    2024年01月16日
    浏览(41)
  • CSS3过渡与动画,2D与3D

    该属性用于定义元素边框的背景图像 语法: border-image:none | url(img) imagesection [/imagewidth] imaghandling 其中imagesection定义用于边框不同部分的图像部分。imagesection值可以由图像上的4条分隔线组成,每条线以像素或者百分比为度量。 imaghandling可以定义的三个,用于控制分隔线

    2024年02月03日
    浏览(36)
  • 👾 笔记 | react-transition-group 实现路由切换过渡动画

    React 18 React router v6 React Transition Group 是一个 React 库,专门用于在 React 应用中管理和处理过渡动画效果。这个库提供了一组组件,包括 Transition、CSSTransition、SwitchTransition 和 TransitionGroup,帮助在组件的进入和退出时应用动画效果。 Transition 是一个与平台无关的组件,通常结合

    2024年03月09日
    浏览(56)
  • 【CSS笔记】CSS动画效果(2d、3d)之渐变色、过渡、变换、平移、缩放、旋转、倾斜、关键帧动画

    这篇文章,主要介绍CSS动画效果(2d、3d)之渐变色、过渡、变换、平移、缩放、旋转、倾斜、关键帧动画。 目录 一、2d动画 1.1、渐变色 (1)线性渐变色 (2)径向渐变色

    2024年02月02日
    浏览(78)
  • 前端高度变化实现过渡动画

    前提:已知初始高度与最终高度。 如果有这个前提,那么这个动画是最好实现的了。 利用最大高度实现过度动画。 但是有缺陷,如果最大高度大于需要的高度,就会有明显的延迟。(相当于设置了初始高度与最终高度) 利用的就是放大,缩小。 这个方法是用css实现最简单

    2024年03月21日
    浏览(42)
  • CSS3 属性: transition过渡 与 transform动画

    CSS3 提供了很多强大的功能,使开发人员可以创建更加吸引人的视觉效果,而不需要依赖于 JavaScript 或 Flash。其中, transition 和 transform 是两个常用的属性,它们分别用于创建平滑的过渡效果和元素的变形效果。下面我们将详细介绍这两个属性的使用方法并给出代码示例。 t

    2024年02月04日
    浏览(38)
  • 【JAVA】CSS3:3D、过渡、动画、布局、伸缩盒

    透视点位置:观察者位置 在2D位移基础上,可以让元素沿z轴移动 cubic-bezier(.17,.67,.83,.67) ✿ cubic-bezier.com 贝塞尔曲线: cubic-bezier(.17,.67,.83,.67) ✿ cubic-bezier.com 效果:鼠标悬浮,图片旋转,字体出现,背景模糊 鼠标悬浮前:  鼠标悬浮后: 帧:一个视频包含多个画面,每一个

    2024年03月22日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包