使用styled-components控制主题切换(有手就行)

简介: 使用styled-components控制主题切换(有手就行)


主题的介绍

在计算机科学中,theme(主题)通常指网页、应用程序或操作系统界面的整体外观和样式。
主题可以包括颜色、字体、图标、背景等元素的组合。
在网页设计中,主题通常是由CSS (层叠样式表)定义的一系列规则集合。
这些规则控制文本、链接、按钮、表格、导航栏和其他组件的样式。
例如,一个主题可以指定黑色背景、白色文本和蓝色链接来创建一个专业和现代的外观。
对于应用程序和操作系统界面,主题通常由开发人员定义并可以通过用户选择进行更改。
主题可以提供不同的视觉效果,例如浅色或深色模式、不同的颜色方案或不同的图标集。
用户可以通过选择自己喜欢的主题来个性化他们的应用程序或操作系统界面。

需要注意以及准备

本篇文章需要使用 ‘styled-components插件控制style样式’

需要引入 antd 组件库

请创建一个theme文件夹,提供一个js文件存放两套主题

本篇文章使用react进行教学

终于不用js麻烦的切换两套不同的css了, 妈妈见了都说好_(:з」∠)_

开始使用

1. theme.js 文件

--- theme.js
--- 准备两套主题
const theme = {
  light: {
    backgroundColor: 'white',
    textColor: 'black'
  },
  dark: {
    backgroundColor: 'black',
    textColor: 'white',
  },
};
export default theme;

2. index.js 文件

/* eslint-disable react-hooks/exhaustive-deps */
import React, { useState} from 'react';
import { GlobalStyle } from './style'
import { ThemeProvider } from 'styled-components';
import theme from '../../utils/theme/theme';
import { Switch } from 'antd'
import { BulbOutlined } from '@ant-design/icons';
const Home = () => {
  // isDarkMode 切换主题的条件
  const [isDarkMode, setIsDarkMode] = useState(false);
  // 取反,等于切换主题样式
  const toggleTheme = () => setIsDarkMode(!isDarkMode);
  return (
      // 判断主题 theme上面引入了所以能用他下面的属性 dark:{} light:{}
      <ThemeProvider theme={isDarkMode ? theme.dark : theme.light}>
        // GlobalStyle是React中的一个组件,它可以用来定义全局样式。
        // 它允许开发者在React应用程序中定义全局样式,以便这些样式可以在整个应用程序中共享。
    // 在React中使用GlobalStyle组件时,可以将全局CSS样式定义在其中,并使用CSS属性来控制应用程序中的所有组件的外观。
        <GlobalStyle />
        <div className='top-operate-container'>
          <div className='operate'>
            <div className='left-container'>
              <ul className='navigate-list'>
                <li>首页</li>
                <li>动态</li>
                <li>发现</li>
              </ul>
            </div>
            <div className='right-container'>
              // 我用的antd的switch控制一键切换主题
              <Switch
                onChange={toggleTheme}
                checkedChildren={<BulbOutlined />}
                unCheckedChildren={<BulbOutlined />}
              />
            </div>
          </div>
        </div>
        <div className='content-container'>
          <div className='main'>
            最近更新
          </div>
        </div>
      </ThemeProvider>
  );
};
export default Home;

3. style.js 文件

// 某些样式我就不放了,你们自己写吧_(:з」∠)_
// 在使用styled-components库定义组件的样式时,可以使用props对象来获取组件的属性值
import { createGlobalStyle } from 'styled-components';
// createGlobalStyle是styled-components库中的一个函数,用于创建一个全局样式组件
// 它使得在React应用程序中定义全局样式变得非常方便,可以在整个应用程序中共享这些样式。
// 这里也可以放类名改样式(例子: .box1)
export const GlobalStyle = createGlobalStyle`
  .box1 { 
     color: ${(props) => props.theme.textColor}
   }
  body {
    background-color: ${(props) => props.theme.backgroundColor};
    color: ${(props) => props.theme.textColor};
    transition: 0.5s all;
  }
`;

4. 完结


至此主题就完全可以用了,您可以根据自己的需求进行扩展,一键开关灯,一键切换主题等…


相关文章
|
人工智能
AI背景颜色变成白色了怎么恢复灰色?
一些刚开始使用AI来做平面设计的朋友,有时候会突然工作界面变成白色,而设置里看了是灰色,然后怎样都调不回来了。贴吧里一篇文章介绍用CTRL+SHIFT+H,实际上这是隐藏画板的快捷键并没有解决问题。
AI背景颜色变成白色了怎么恢复灰色?
|
7月前
|
人工智能 安全
阿里巴巴 AI Coding 分享会 Qoder Together 杭州站诚邀你的参与!
Qoder Together ,不止技术分享,更是思维共振与灵感迸发。我们面向全球 AI Coding 爱好者,邀请 Qoder 团队、实战用户、AI Coding 探索者齐聚一堂,交流激发创意,碰撞拓展边界,重新定义智能编程未来。
460 0
|
5月前
|
人工智能 自然语言处理 监控
海外上线原生 APP的流程
海外上线原生APP需统筹账号注册、法律合规、多语言本地化、支付税务及应用商店审核。提前准备D-U-N-S码与身份验证,严格遵循GDPR/CCPA隐私规范,适配AI内容声明与内容过滤机制,优化ASO与服务器布局,并集成全球推送与数据监控体系,确保稳定运营。#APP外包 #海外APP #软件外包公司
|
存储 缓存 开发者
Mooncake 最新进展:SGLang 和 LMCache 基于 Mooncake 实现高效 PD 分离框架
近期,Mooncake 项目与 SGLang、vLLM 等主流大模型推理框架实现合作和适配,这些开源大模型推理框架可以通过使用 Mooncake 发布的 whl 包,支持 pip安装,docker 镜像部署等,实现了 PD 分离框架,极大提升了模型推理效率。
|
资源调度 搜索推荐 Shell
使用VitePress静态网站生成器创建组件库文档网站并部署到GitHub
本文介绍了如何使用 Vue3、TypeScript 和 Vite 开发组件库并将其发布到 npm。文章详细描述了安装依赖、配置项目、创建文档网站以及编写组件文档的步骤。通过使用 VitePress,可以轻松搭建组件库的文档站点,并实现 Algolia 搜索功能。此外,还提供了自动化脚本用于部署静态网站至 GitHub 以及发布组件库到 npm。最后,展示了完整的目录结构和网站效果。
750 1
使用VitePress静态网站生成器创建组件库文档网站并部署到GitHub
|
存储 数据管理 C语言
C 语言中的文件操作:数据持久化的关键桥梁
C语言中的文件操作是实现数据持久化的重要手段,通过 fopen、fclose、fread、fwrite 等函数,可以实现对文件的创建、读写和关闭,构建程序与外部数据存储之间的桥梁。
|
安全 Oracle Java
Java 中的运算符重载
Java 中的运算符重载
325 19
|
JavaScript 前端开发
CMD和UMD,ES Module的差别
CMD和UMD,ES Module的差别
|
存储 Shell API
Casbin是一个强大的、开源的访问控制库,支持访问控制模型如ACL、RBAC、ABAC等。
Casbin是一个强大的、开源的访问控制库,支持访问控制模型如ACL、RBAC、ABAC等。