我在 React 页面上有一张图片。当状态更新为新图像时,我想执行以下过渡效果:
- 原始图像应该放大和淡出
- 新图像也应该放大和淡入
效果应该类似于穿过一堵墙到达新场景。
我怎样才能在 React 中做到这一点?
原文由 kojow7 发布,翻译遵循 CC BY-SA 4.0 许可协议
我在 React 页面上有一张图片。当状态更新为新图像时,我想执行以下过渡效果:
效果应该类似于穿过一堵墙到达新场景。
我怎样才能在 React 中做到这一点?
原文由 kojow7 发布,翻译遵循 CC BY-SA 4.0 许可协议
这对我有用( 链接):
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;
}
原文由 Kevin He 发布,翻译遵循 CC BY-SA 4.0 许可协议
13 回答13k 阅读
7 回答2.1k 阅读
3 回答1.3k 阅读✓ 已解决
3 回答880 阅读✓ 已解决
6 回答1.2k 阅读✓ 已解决
2 回答1.4k 阅读✓ 已解决
4 回答1.3k 阅读✓ 已解决
正如@pgsandstrom 提到的, React Transition Group 是必经之路。不幸的是,它对开发人员不是很友好(学习曲线相当陡峭)。
这是一个工作示例: https ://codesandbox.io/s/6lmv669kz
✔ 原始图像在淡出时放大
✔ 新图像在淡入时放大
TransitionExample.js
样式.css