Кнопка с эффектом волны (Ripple Effect)
Файлы index.html
и script.js
уже предоставлены в виртуальной машине (VM). В целом, вам нужно добавить код только в файлы script.js
и style.css
.
Этот код отображает компонент кнопки, который создает эффект волны при нажатии. Вот как он работает:
- Хук
useState()
используется для создания двух переменных состояния: coords
и isRippling
. Переменная coords
хранит координаты указателя, а isRippling
хранит состояние анимации кнопки.
- Хук
useEffect()
используется для изменения значения isRippling
каждый раз, когда изменяется переменная состояния coords
. Это запускает анимацию эффекта волны.
- Функция
setTimeout()
используется в предыдущем хуке для очистки анимации после ее завершения.
- Другой хук
useEffect()
используется для сброса coords
каждый раз, когда переменная состояния isRippling
имеет значение false
.
- Событие
onClick
обрабатывается путем обновления переменной состояния coords
и вызова переданной обратной функции (callback).
Вот код компонента RippleButton
:
const RippleButton = ({ children, onClick }) => {
const [coords, setCoords] = React.useState({ x: -1, y: -1 });
const [isRippling, setIsRippling] = React.useState(false);
React.useEffect(() => {
if (coords.x !== -1 && coords.y !== -1) {
setIsRippling(true);
setTimeout(() => setIsRippling(false), 300);
} else setIsRippling(false);
}, [coords]);
React.useEffect(() => {
if (!isRippling) setCoords({ x: -1, y: -1 });
}, [isRippling]);
return (
<button
className="ripple-button"
onClick={(e) => {
const rect = e.target.getBoundingClientRect();
setCoords({ x: e.clientX - rect.left, y: e.clientY - rect.top });
onClick && onClick(e);
}}
>
{isRippling && (
<span
className="ripple"
style={{
left: coords.x,
top: coords.y
}}
/>
)}
<span className="content">{children}</span>
</button>
);
};
Вы можете использовать этот компонент следующим образом:
ReactDOM.createRoot(document.getElementById("root")).render(
<RippleButton onClick={(e) => console.log(e)}>Click me</RippleButton>
);
А вот CSS для компонента RippleButton
:
.ripple-button {
border-radius: 4px;
border: none;
margin: 8px;
padding: 14px 24px;
background: #1976d2;
color: #fff;
overflow: hidden;
position: relative;
cursor: pointer;
}
.ripple-button > .ripple {
width: 20px;
height: 20px;
position: absolute;
background: #63a4ff;
display: block;
content: "";
border-radius: 9999px;
opacity: 1;
animation: 0.9s ease 1 forwards ripple-effect;
}
@keyframes ripple-effect {
0% {
transform: scale(1);
opacity: 1;
}
50% {
transform: scale(10);
opacity: 0.375;
}
100% {
transform: scale(35);
opacity: 0;
}
}
.ripple-button > .content {
position: relative;
z-index: 2;
}
Нажмите на кнопку 'Go Live' в правом нижнем углу, чтобы запустить веб-сервис на порту 8080. Затем вы можете обновить вкладку Web 8080, чтобы предварительно просмотреть веб-страницу.