有條件地將className更改為css模組(React)
P粉799885311
P粉799885311 2023-08-17 18:10:17
0
1
419

我正在嘗試在用戶懸停在我的網站導航欄上時播放動畫。我試圖透過根據滑鼠是否懸停在導覽列上來更改css模組來實現這一目標。我正在努力弄清楚為什麼這段程式碼不起作用。非常感謝任何幫助!

Navbar.jsx:

import React, { useState } from "react"; import { Link } from "react-router-dom"; import styles from "../styles/Navbar.module.css"; const Navbar = () => { const [className, setClassName] = useState("line-after"); return ( 
setClassName("line::before")} onMouseLeave={() => setClassName("line-after")} >
); }; export default Navbar;

Css模組:

.line::before { content: ""; position: absolute; top: 0; left: 0; width: 55px; height: 1px; background: black; animation-name: animate; animation-duration: 1s; } .line-after { margin: 40px 40px 40px 40px; width: 55px; height: 1px; background: white; position: relative; } @keyframes animate { 0% { left: 0; } 100% { left: 100%; } }

當滑鼠離開並進入導覽列時,我正在更改className的狀態。然而,它說我的狀態變數className從未被使用過,所以我認為這是問題所在。不確定如何修復它。

P粉799885311
P粉799885311

全部回覆 (1)
P粉124890778

您可以完全不使用React邏輯來實現這一點,您可以簡單地使用CSS動畫(就像您目前正在做的那樣)和CSS偽類(在這種情況下是:hover),而不是動態地改變元素的類別。

https://developer.mozilla.org/en-US/docs/Web/CSS/:hover

#請檢查這是否對您有用:如何在懸停時播放動畫並在懸停不活動時暫停

    最新下載
    更多>
    網站特效
    網站源碼
    網站素材
    前端模板
    關於我們 免責聲明 Sitemap
    PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!