当前位置: 首页 > news >正文

网站建设是必须的吗东莞高端网站建设收费标准

网站建设是必须的吗,东莞高端网站建设收费标准,crm客户管理系统服务电话,企业网站建设会计分录目录 效果预览完整代码我遇到的BUG问题代码BUG1:暗黑模式下内容区不变成深色BUG2:光亮模式下的左右区域是深色 补充知识ConfigProvider是什么?Ant Design中的theme如何使用?theme 配置的常见字段主题算法通过 useToken 获取主题 效…

目录

  • 效果预览
  • 完整代码
  • 我遇到的BUG
    • 问题代码
    • BUG1:暗黑模式下内容区不变成深色
    • BUG2:光亮模式下的左右区域是深色
  • 补充知识
    • ConfigProvider是什么?
    • Ant Design中的theme如何使用?
      • theme 配置的常见字段
      • 主题算法
      • 通过 useToken 获取主题

效果预览

暗黑模式:
在这里插入图片描述

光亮模式:
在这里插入图片描述

完整代码

import React, { useState } from 'react';
import { Breadcrumb, Layout, Menu, theme, ConfigProvider, Switch } from 'antd';const { Header, Content, Footer } = Layout;const items = [{ key: '0', label: '测试' }];const App: React.FC = () => {const [isDarkMode, setIsDarkMode] = useState(false);return (<ConfigProvidertheme={{algorithm: isDarkMode ? theme.darkAlgorithm : theme.defaultAlgorithm,}}>{/* useToken 必须在 ConfigProvider 作用域内 */}<ThemeWrapper isDarkMode={isDarkMode} setIsDarkMode={setIsDarkMode} /></ConfigProvider>);
};const ThemeWrapper: React.FC<{ isDarkMode: boolean; setIsDarkMode: React.Dispatch<React.SetStateAction<boolean>> }> = ({ isDarkMode, setIsDarkMode }) => {const { token } = theme.useToken(); // 确保 useToken 在 ConfigProvider 作用域内return (<Layout style={{minHeight : window.innerHeight}}><Headerstyle={{display: 'flex',alignItems: 'center',background: token.colorBgElevated, // 修正 Header 适配暗黑模式}}><Menutheme={isDarkMode ? 'dark' : 'light'}mode="horizontal"defaultSelectedKeys={['0']}items={items}style={{flex: 1,minWidth: 0,background: token.colorBgElevated, // 确保 Menu 颜色一致}}/><div><Switchchecked={!isDarkMode}onChange={() => setIsDarkMode(!isDarkMode)}checkedChildren="🌙"unCheckedChildren="☀️"/></div></Header><Content style={{ padding: '0 48px' }}><Breadcrumbstyle={{ margin: '16px 0' }}items={[{ title: 'Home' }, { title: 'List' }, { title: 'App' }]}/><divstyle={{background: token.colorBgContainer, // 确保背景颜色正确color: token.colorText, // 文字颜色适配暗黑模式minHeight: 580,padding: 24,borderRadius: token.borderRadiusLG,}}>Content</div></Content><Footer style={{ background: token.colorBgElevated, textAlign: 'center' }}>Ant Design ©{new Date().getFullYear()} Created by Ant UED</Footer></Layout>);
};export default App;

我遇到的BUG

问题代码

import React, { useState } from 'react';
import { Breadcrumb, Layout, Menu, theme, ConfigProvider, Switch } from 'antd';
import './index.css';const { Header, Content, Footer } = Layout;const items = [{key: 0,label: '测试',},
];const App: React.FC = () => {// 主题切换状态const [isDarkMode, setIsDarkMode] = useState(false);// 获取当前主题 token(应该在组件顶层调用)const { token } = theme.useToken();return (<ConfigProvidertheme={{algorithm: isDarkMode ? theme.darkAlgorithm : theme.defaultAlgorithm,}}><Layout><Header style={{ display: 'flex', alignItems: 'center' }}><Menutheme={isDarkMode ? 'dark' : 'light'}mode="horizontal"defaultSelectedKeys={['0']}items={items}style={{ flex: 1, minWidth: 0 }}/><Switchchecked={!isDarkMode}onChange={() => setIsDarkMode(!isDarkMode)}checkedChildren="🌙"unCheckedChildren="☀️"/></Header><Content style={{ padding: '0 48px' }}><Breadcrumbstyle={{ margin: '16px 0' }}items={[{ title: 'Home' }, { title: 'List' }, { title: 'App' }]}/><divstyle={{backgroundColor: token.colorBgContainer,minHeight: 1080,padding: 24,borderRadius: token.borderRadiusLG,}}>Content</div></Content><Footer style={{ textAlign: 'center' }}>Ant Design ©{new Date().getFullYear()} Created by Ant UED</Footer></Layout></ConfigProvider>);
};export default App;

BUG1:暗黑模式下内容区不变成深色

效果如图:
在这里插入图片描述

原因:theme.useToken() 的 token 在 ConfigProvider 重新渲染时没有立即更新。
解决办法:确保 theme.useToken() 在 ConfigProvider 作用域内,并且 ConfigProvider 重新渲染时 token 正确更新。

BUG2:光亮模式下的左右区域是深色

效果如下:
在这里插入图片描述
产生原因:Header 组件默认没有使用 theme.useToken() 提供的背景色,而是继承了 Ant Design 默认的 light 主题颜色
解决办法:使用 token.colorBgElevated 作为 Header 的背景(它适用于暗黑模式的顶层容器)。确保 Header、Menu、Switch 共享相同的 backgroundColor。

补充知识

ConfigProvider是什么?

ConfigProvider 是 Ant Design 中的一个组件,用于在应用中全局配置和定制 Ant Design 组件的默认行为和主题。它是一个上下文提供器,用来设置应用中的全局配置,比如主题、国际化语言、组件的默认样式等。

Ant Design中的theme如何使用?

在 Ant Design 中,theme 是用于设置和管理 UI 样式的工具,通常与 ConfigProvider 一起使用来定制整个应用的视觉风格。theme 允许开发者通过配置颜色、字体、布局、组件样式等来调整 Ant Design 组件的外观,使其与应用的整体设计保持一致。

theme 配置的常见字段

  • colorPrimary:设置主色调。影响许多组件的颜色,如按钮、链接、选中状态等。
  • colorLink:设置链接文字的颜色。
  • colorBgBase:设置基础背景颜色。
  • colorTextBase:设置基础文字颜色。
  • borderRadiusBase:设置全局组件的边框圆角。
  • fontSizeBase:设置基础字体大小。
  • size:设置默认组件尺寸(如 small, middle, large)。

主题算法

Ant Design 支持多种主题算法,其中常见的包括:

  • theme.defaultAlgorithm:默认主题算法,通常用于浅色模式。
  • theme.darkAlgorithm:暗黑主题算法,用于暗黑模式。

通过 useToken 获取主题

在使用主题时,你可以通过 theme.useToken 来访问当前的主题 token 和样式变量。例如,访问当前主题下的背景色、文本色等:

import React from 'react';
import { theme } from 'antd';const App: React.FC = () => {const { token } = theme.useToken();return (<div style={{ backgroundColor: token.colorBgContainer, color: token.colorText }}>Content with dynamic theme</div>);
};export default App;
http://www.dtcms.com/a/553855.html

相关文章:

  • AWS + Discuz!:社区站架构的现代化玩法
  • Linux命令之mtr命令
  • 网站优化待遇河南seo网站多少钱
  • Spring Boot常见问题
  • dw做网站实例沈阳建站费用
  • 09-MySQL内外连接
  • 【Linux】自动化构建工具make和Makefile和第一个系统程序—进度条
  • YOLO python 实现多种物体识别(时钟,水杯,小熊,路人,车辆)
  • wordpress如何自动采集网站图片建模培训
  • 建设银行网站会员怎么用装修设计公司快餐店
  • 华宇亮相2025丽泽法务论坛,共探法治前沿与法商融合新路径
  • 嫦娥号地月轨道、环月(一个月)MATLAB仿真
  • Spring AI Alibaba 【六】
  • .NET10 - 尝试一下Blazor Web Assembly Standalone App的fingerprint新特性
  • 浏览器使用 <embed> 标签预览 PDF 的原理
  • 未来之窗昭和仙君(四十七)开发商品进销存——东方仙盟筑基期
  • 交流平台网站架构怎么做wordpress客户端登录界面
  • 网站附件下载表格怎么做营销是做什么
  • Xcode26升级以后重要
  • Mac电脑解决sudo密码问题方法
  • 仓颉语言宏(Cangjie Macros)详细介绍及强大使用
  • Python异常、模块、包
  • flink 流式窗口
  • 仿京东电商的网站开发智慧团建网站什么时候维护好
  • 23.NAT之Easy-IP
  • Godot游戏开发——C# (一)
  • PyTorch实战:从零搭建CV模型技术文章大纲
  • 高效的DDC可编程控制器风机水泵空调节能控制器公司
  • PIL (Python Imaging Library) 相关方法详解1
  • U-Net 家族全解析