在本指南中,我们将引导您完成向 React 或 Next.js 应用程序添加深色和浅色主题支持的步骤。这种方法将允许用户在主题之间切换,并且 UI 将相应更新。
接下来,创建一个允许用户在主题之间切换的组件。该组件将包括一个用于切换主题状态的按钮和一个允许用户选择他们喜欢的主题的菜单。
import React, { useState } from 'react'; import { FaMoon, FaSun } from 'react-icons/fa'; function ThemeToggle({ theme, handleThemeChange }) { const [menuOpen, setMenuOpen] = useState(false); const toggleMenu = () => { setMenuOpen(!menuOpen); }; return ( <li className="m-auto mx-3" role="button"> <div className="theme-toggle"> <button className="theme-toggle-btn" onClick={toggleMenu}> {theme === 'dark' ? <FaMoon /> : <FaSun />} </button> {menuOpen && ( <div className="theme-menu"> <p className="theme-title">Toggle Dark Mode</p> <ul> <li onClick={() => handleThemeChange('dark')} className={theme === 'dark' ? 'active' : ''} > <FaMoon /> Dark Mode </li> <li onClick={() => handleThemeChange('light')} className={theme === 'light' ? 'active' : ''} > <FaSun /> Light Mode </li> </ul> </div> )} </div> </li> ); } export default ThemeToggle;
在 index.css 或 App.css 文件中为深色和浅色主题定义 CSS 变量。这些变量将根据活动主题控制整个应用程序的样式。
/* Default Theme Variables */ :root { --white-color: #ffff; --background-color: black; --text-color: #ffff; --games-text: #452c88; --games-text-2: #60882c; --game-bg-card: #252331; --card-wrapper-color: #252331; --custom-input-bg: #14131b; --siderbar-bg: #1a1923; --profile-badge-color: #252364; --card-header-bg: #032b53; --theme-color: #df1b47; --table-row-bg-color: #1e1d29; --table-row-header-color: #252364; --button-bg-color: #252364; --dark-light-bg-color: #353940; } /* Dark Theme */ body.dark-mode { --white-color: #ffff; --background-color: black; --text-color: #ffff; --game-bg-card: #252331; --card-wrapper-color: #252331; --custom-input-bg: #14131b; --siderbar-bg: #1a1923; --profile-badge-color: #252364; --card-header-bg: #032b53; --table-row-bg-color: #1e1d29; --table-row-header-color: #252364; --button-bg-color: #252364; --dark-light-bg-color: #353940; } /* Light Theme */ body.light-mode { --white-color: #ffff; --background-color: rgb(253, 251, 251); --text-color: #0f0e0ecc; --game-bg-card: #eae8eb; --custom-input-bg: #e0e0e0; --card-wrapper-color: #e1e0e6; --custom-input-bg: #e6e6e6; --siderbar-bg: #e5e5e5; --profile-badge-color: #e64b4b; --card-header-bg: #a6cbf0; --table-row-bg-color: #ffffff; --table-row-header-color: #f2f4f6; --button-bg-color: #df1b47; --dark-light-bg-color: #c5c1c1; }
以上是在 React/Next.js 中添加深色和浅色主题支持的详细内容。更多信息请关注PHP中文网其他相关文章!