有条件地将className更改为css模块(React)
P粉799885311
P粉799885311 2023-08-17 18:10:17
0
1
353
<p>我正在尝试在用户悬停在我的网站导航栏上时播放动画。我试图通过根据鼠标是否悬停在导航栏上来更改css模块来实现这一目标。我正在努力弄清楚为什么这段代码不起作用。非常感谢任何帮助!</p> <p>Navbar.jsx:</p> <pre class="brush:php;toolbar:false;">import React, { useState } from "react"; import { Link } from "react-router-dom"; import styles from "../styles/Navbar.module.css"; const Navbar = () =&gt; { const [className, setClassName] = useState("line-after"); return ( &lt;div className="navbar" onMouseEnter={() =&gt; setClassName("line::before")} onMouseLeave={() =&gt; setClassName("line-after")} &gt; &lt;nav&gt; &lt;Link to="/about" className="home-page"&gt; Bob &lt;br /&gt; Jones &lt;/Link&gt; &lt;ul&gt; &lt;li&gt; &lt;Link to="/about" className="about-page"&gt; About &lt;/Link&gt; &lt;/li&gt; &lt;li&gt; &lt;Link to="/resume" className="resume-page"&gt; Resume &lt;/Link&gt; &lt;/li&gt; &lt;li&gt; &lt;Link to="/contact" className="contact-page"&gt; Contact &lt;/Link&gt; &lt;/li&gt; &lt;/ul&gt; &lt;/nav&gt; &lt;div className={styles.className}&gt;&lt;/div&gt; &lt;/div&gt; ); }; export default Navbar;</pre> <p>Css模块:</p> <pre class="brush:php;toolbar:false;">.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%; } }</pre> <p>当鼠标离开和进入导航栏时,我正在更改className的状态。然而,它说我的状态变量className从未被使用过,所以我认为这是问题所在。不确定如何修复它。</p>
P粉799885311
P粉799885311

최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!