状态改变时在 React JS 中实现过渡效果

     2023-03-06     17

关键词:

【中文标题】状态改变时在 React JS 中实现过渡效果【英文标题】:Implementing transition effects in React JS when state changes 【发布时间】:2019-03-01 14:31:09 【问题描述】:

我在 React 页面上有一张图片。当状态更新为新图像时,我想执行以下过渡效果:

原始图像应放大和淡出 新图像也应该放大和淡入

效果应该类似于穿过墙壁进入新场景。

我如何在 React 中做到这一点?

【问题讨论】:

给 react-pose 一个旋转popmotion.io/pose 这更像是一个 CSS 问题。更改元素的 className,并使用 CSS 过渡对其进行动画处理 @Mikkel 好吧,除了 React 重新渲染页面时,旧图像消失了,新图像处于状态。所以,一个合适的解决方案应该是 React 和 CSS 的结合。可能与 componentWillUpdate 结合 CSS 有关,但事实证明它比我想象的要困难一些。 @azium 不确定这是否适合我。如果不需要,我宁愿不使用第三方库。另外,我似乎找不到任何关于它能够处理状态变化之间转换的信息。 听起来你正在用新图像替换状态中的图像,导致 React 重新渲染并立即删除旧图像,因此会破坏任何随之而来的过渡。尝试在不删除旧图像的情况下将新图像添加到状态中,然后对两个图像进行动画处理,然后从状态中删除旧图像? 【参考方案1】:

正如@pgsandstrom 所提到的,React Transition Group 是要走的路。不幸的是,它对开发人员不太友好(学习曲线相当陡峭)。

这是一个工作示例:https://codesandbox.io/s/6lmv669kz

✔ 原始图像在淡出时放大

✔ 新图像在淡入时放大

TransitionExample.js

import random from "lodash/random";
import React,  Component  from "react";
import  CSSTransition, TransitionGroup  from "react-transition-group";
import uuid from "uuid/v1";

const arr = [
  
    id: uuid(),
    url: `https://loremflickr.com/600/100?lock=$random(0, 999)`
  ,
  
    id: uuid(),
    url: `https://loremflickr.com/600/100?lock=$random(0, 999)`
  ,
  
    id: uuid(),
    url: `https://loremflickr.com/600/100?lock=$random(0, 999)`
  
];

export default class TransitionExample extends Component 
  state = 
    index: 0,
    selected: arr[0]
  ;

  nextImage = () =>
    this.setState(prevState => 
      const newIndex = prevState.index < arr.length - 1 ? prevState.index + 1 : 0;
      return 
        index: newIndex,
        selected: arr[newIndex]
      ;
    );

  render = () => (
    <div className="app">
      <div style= marginBottom: 30, height: 100 >
        <TransitionGroup>
          <CSSTransition
            key=this.state.selected.id
            timeout=1000
            classNames="messageout"
          >
            <div style= marginTop: 20 >
              <img className="centered-image" src=this.state.selected.url />
            </div>
          </CSSTransition>
        </TransitionGroup>
      </div>
      <div style= textAlign: "center" >
        <button
          className="uk-button uk-button-primary"
          onClick=this.nextImage
        >
          Next Image
        </button>
      </div>
    </div>
  );

styles.css

.app 
  margin: 0 auto;
  overflow: hidden;
  width: 700px;
  height: 800px;


.centered-image 
  display: block;
  margin: 0 auto;


/* starting ENTER animation */
.messageout-enter 
  position: absolute;
  top: 0;
  left: calc(13% + 5px);
  right: calc(13% + 5px);
  opacity: 0.01;
  transform: translateY(0%) scale(0.01);


/* ending ENTER animation */
.messageout-enter-active 
  opacity: 1;
  transform: translateY(0%) scale(1);
  transition: all 1000ms ease-in-out;


/* starting EXIT animation */
.messageout-exit 
  opacity: 1;
  transform: scale(1.01);


/* ending EXIT animation */
.messageout-exit-active 
  opacity: 0;
  transform: scale(4);
  transition: all 1000ms ease-in-out;

【讨论】:

【参考方案2】:

这对我有用 (link):

index.js:

import React from "react";
import  render  from "react-dom";

import "./styles.scss";

const src1 =
  "https://www.nba.com/dam/assets/121028030322-james-harden-traded-102712-home-t1.jpg";
const src2 = "https://www.nba.com/rockets/sites/rockets/files/wcwebsite.jpg";

var state = 
  toggle: true
;

class App extends React.Component 
  render() 
    const cn1 = "imgFrame " + (state.toggle ? "toggleOut" : "toggleIn");
    const cn2 = "imgFrame " + (state.toggle ? "toggleIn" : "toggleOut");
    return (
      <div>
        <img className=cn1 src=src1 alt="img1" />
        <img className=cn2 src=src2 alt="img2" />
        <button
          onClick=() => 
            state.toggle = !state.toggle;
            this.forceUpdate();
          
        >
          click me to toggle
        </button>
        <h1>Hello</h1>
      </div>
    );
  


render(<App />, document.getElementById("app"));

style.scss:

html,
body 
  background-color: papayawhip;
  font-family: sans-serif;

  h1 
    color: tomato;
  


@keyframes fadeout 
  0% 
    opacity: 1;
    transform: scale(1);
  
  100% 
    opacity: 0;
    transform: scale(0.9);
  


@keyframes fadein 
  0% 
    opacity: 0;
    transform: scale(1.1);
  
  100% 
    opacity: 1;
    transform: scale(1);
  


.toggleOut 
  animation: fadeout 500ms;
  opacity: 0;


.toggleIn 
  animation: fadein 500ms;
  opacity: 1;


.imgFrame 
  position: absolute;
  top: 10px;
  left: 10px;
  width: 200px;
  height: 200px;


button 
  position: absolute;
  top: 220px;

【讨论】:

如果我有 3 张或多于 2 张图片,我该如何处理?【参考方案3】:

听起来您正在寻找React Transition Group。这是解决这些问题的“官方”方式。具体来说,我认为this 是您应该使用的。掌握窍门可能有点棘手,但一旦你理解了它,它就会非常好用且功能强大。

【讨论】:

滚动时在标题上添加平滑过渡

...更改标题的颜色。我做了一个小的javascript代码来做这个改变,但我也想在这个改变上添加一个平滑的过渡。谁能帮我?谢谢这是我的代码和codepen的链接:https://codepen.io/ 查看详情

如何在 React TypeScript 中实现 e 和 props?

...:我有一个JS组件,我在其中定义了一些普通的jsx函数和状态,现在我想将它们用作tsx文件中的道具,但是因为我我是初学者,我很困惑。这是我想在tsx中实现的js版本:exportclassFormUserDetailsex 查看详情

在 react.js 中实现 render 方法

】在react.js中实现render方法【英文标题】:implementingtherendermethodinreact.js【发布时间】:2017-01-0620:58:06【问题描述】:我在这里查看一个React/Redux示例:http://redux.js.org/docs/basics/ExampleTodoList.html请注意以下内容永远不会完成:constComm... 查看详情

react中实现keepalive组件缓存效果(代码片段)

...,react-router-dom5结构:代码:cache-types.js//缓存状态exportconstCREATE='CREATE';//创建exportconstCREATED='CREATED';//创建成功exportconstACTIVE='ACTIVE';//激活exportconstDESTROY='DESTROY';//销毁 CacheContext 查看详情

在 React.js 中实现 Read More 链接

】在React.js中实现ReadMore链接【英文标题】:ImplementingaReadMorelinkinReact.js【发布时间】:2015-07-1119:50:53【问题描述】:我正在尝试实现一个ReadMore链接,该链接扩展为显示点击后更多文字。我正在尝试以React的方式做到这一点。<!... 查看详情

在 React Js 中实现 Quickblox 视频会议时获取“DTLS 警报”

】在ReactJs中实现Quickblox视频会议时获取“DTLS警报”【英文标题】:Getting\'DTLSalert\'whileimplementingQuickbloxVideoConferencinginReactJs【发布时间】:2021-04-0110:20:07【问题描述】:我正在我的React应用程序中实现Quickblox视频会议服务-但是我... 查看详情

如何在 React.js 中实现 cloudinary 产品库

】如何在React.js中实现cloudinary产品库【英文标题】:howtoimplementcloudinaryProductGalleryinReact.js【发布时间】:2021-05-3110:19:07【问题描述】:我正在尝试在我的电子商务项目中使用CloudinaryProductGallery,但不知道如何实施。此Cloudinary产... 查看详情

我想在辅助函数中操作 React 类组件中存在的状态。我想在 Typescript 中实现相同的目标

】我想在辅助函数中操作React类组件中存在的状态。我想在Typescript中实现相同的目标【英文标题】:IwanttomanipulatethestatepresentinReactclasscomponentinahelperfunction.IwanttoachievethesameinTypescript【发布时间】:2020-06-0201:55:40【问题描述】:我... 查看详情

[decorator]react中实现vuewatch

...考技术Areact比如在开发echarts应用时,可能会通过一些值改变时,调用echartsAPI画图,hook可以使用useEffect监听值改变,但是class组件我看没有很好的写法,要是可以按照vue的写法就很方便了。这个就很合适watch对象中的key就是我们... 查看详情

C#在拖放时在ListView中实现自动滚动

】C#在拖放时在ListView中实现自动滚动【英文标题】:C#ImplementingAuto-ScrollinaListViewwhileDrag&Dropping【发布时间】:2010-10-1405:23:09【问题描述】:如何在WinformsListView中实现自动滚动(例如,当您靠近顶部或底部时,ListView会滚动)... 查看详情

在动画集结束时在 MonoTouch 中实现 CAKeyFrameAnimation 回调?

】在动画集结束时在MonoTouch中实现CAKeyFrameAnimation回调?【英文标题】:ImplementingaCAKeyFrameAnimationcallbackinMonoTouchattheendofananimationset?【发布时间】:2010-02-0806:34:34【问题描述】:我的代码有效并且我制作了动画,但我不知道该怎么... 查看详情

如何在没有外部库的情况下在 React 中实现 Google Maps JS API?

】如何在没有外部库的情况下在React中实现GoogleMapsJSAPI?【英文标题】:HowtoimplementGoogleMapsJSAPIinReactwithoutanexternallibrary?【发布时间】:2018-01-0719:52:56【问题描述】:我正在尝试在React中实现外部API,并希望能够使用GoogleMaps的API在... 查看详情

css3hover平滑过渡效果,鼠标经过元素,背景渐隐渐现效果

下面实例,演示,鼠标经过时,改变div宽度,平滑改变,带动画div{width:100px;height:100px;background:blue;transition:width2s;-moz-transition:width2s;/*Firefox4*/-webkit-transition:width2s;/*SafariandChrome*/-o-transition:width2s;/* 查看详情

react, css) 淡入淡出的过渡 css,当背景图像用 className 改变时

...019-08-2519:47:20【问题描述】:我每3秒更改一个div的类名(状态更改,使用setInterval)。每个类都有不同的背景图像。我想在背景图像发生变化时淡 查看详情

一次生成输出时在python中实现机器学习算法

】一次生成输出时在python中实现机器学习算法【英文标题】:Implementingamachinelearningalgorithminpythonwhenoutputisgeneratedone-at-a-time【发布时间】:2022-01-2406:14:34【问题描述】:我有一个大型的黑盒模型,我正在尝试对其进行校准,并且... 查看详情

iOS 7 3D画廊过渡效果

...ct【发布时间】:2014-04-0917:41:48【问题描述】:如何在iOS7中实现以下链接中的过渡效果?http://www.jqueryscript.net/demo/3DGallery/index.html谢谢!【问题讨论】:【参考方案1】:检查https://www.cocoacontrols.com/controls/icarou 查看详情

#transition:添加弹出过渡效果(代码片段)

...下几个步骤来实现:第一,在默认样式中声明元素的初始状态样式;第二,声明过渡元素中点值样式,比如悬浮状态;第三,在默认样式中通过添加过渡函数,添加一些不同的样式。transit 查看详情

如何在 React Redux 中实现自包含组件?

...浏览器。我想构建一个可以包含它自己并且每个都有自己状态的组件。如下:Tree 查看详情