使用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. 完结


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


相关文章
|
2月前
|
前端开发
导航新风尚:CSS梯形设计,让网站菜单不再单调!
导航新风尚:CSS梯形设计,让网站菜单不再单调!
|
2月前
|
前端开发 JavaScript 数据可视化
使用React的函数式组件实现一个具有过渡变化、刻度切换、点击高亮的柱状图DIY组件
本文展示了如何使用React的函数式组件实现一个具有过渡变化、刻度切换、点击高亮效果的自定义柱状图组件,并提供了完整的示例代码和实现效果。
58 1
使用React的函数式组件实现一个具有过渡变化、刻度切换、点击高亮的柱状图DIY组件
|
2月前
|
前端开发
一键复制,霓虹灯效果:CSS动画,为设计添彩!
一键复制,霓虹灯效果:CSS动画,为设计添彩!
|
3月前
|
JavaScript
vue + d3.js(v6) 绘制【树状图/思维导图】可折叠/展开,可点击跳转,可带标签
vue + d3.js(v6) 绘制【树状图/思维导图】可折叠/展开,可点击跳转,可带标签
406 1
|
5月前
|
缓存 前端开发 JavaScript
【亮剑】在React中如何通过点击事件控制组件显示与隐藏,包括基础概念和高级应用
【4月更文挑战第30天】本文介绍了在React中如何通过点击事件控制组件显示与隐藏,包括基础概念和高级应用。使用`useState`钩子和Context API可实现状态驱动的条件渲染,通过CSS类控制组件样式,或利用React Portals在DOM不同位置渲染。性能优化应注意避免不必要的渲染、合理使用Keys、优化事件处理器、使用Memoization及清理资源。测试和验证确保逻辑正确性,以构建动态用户界面并提升应用性能。
494 0
|
前端开发 JavaScript
【React工作记录八十】 一步步教你用taro封装一个公司库的下拉组件
【React工作记录八十】 一步步教你用taro封装一个公司库的下拉组件
101 0
|
JavaScript
WebGis——Pixi开发vue项目之实现闪烁点功能(二)
WebGis——Pixi开发vue项目之实现闪烁点功能(二)
|
JavaScript 定位技术
WebGis——Pixi开发vue项目之使用遮罩实现图形缓慢填充颜色(三)
WebGis——Pixi开发vue项目之使用遮罩实现图形缓慢填充颜色(三)
|
JavaScript 前端开发 定位技术
WebGis——Pixi开发vue项目之创建pixi应用并显示一个精灵(一)
WebGis——Pixi开发vue项目之创建pixi应用并显示一个精灵(一)
|
XML JavaScript 前端开发
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换
192 0
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换