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


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


相关文章
|
4月前
|
JavaScript
使用Vue实现半自动打字机特效
本文介绍了如何使用Vue实现一个半自动打字机特效,通过自定义组件和计时器逐字显示文本内容,并提供了详细的源码实现和效果展示。
156 1
|
5月前
|
开发者
小而美的IKUN-UI组件库源码学习(按钮 Button)
小而美的IKUN-UI组件库源码学习(按钮 Button)
35 0
|
存储 前端开发
Vue+Vuex配合实现动态换肤| 青训营
Vue+Vuex配合实现动态换肤| 青训营
218 0
|
JavaScript
WebGis——Pixi开发vue项目之实现闪烁点功能(二)
WebGis——Pixi开发vue项目之实现闪烁点功能(二)
|
JavaScript 前端开发
哈~这个vue3组件库中的组件真的是超多,不来试试吗?
随着vue在国内的越来越火,也应运而生了很多的优秀的UI组件库。都很有特点,也比较好用。如大家都能耳熟能详的 element-ui 和 Ant Design Vue都是非常不错的。可惜的是 element-ui 不再维护升级vue3了,不过它的继任者 element-plus确实正在如火如荼的开发着,支持vue3。喜欢 element-ui的一定不要错过它。
哈~这个vue3组件库中的组件真的是超多,不来试试吗?
|
前端开发
react笔记之学习之内联样式和样式表
react笔记之学习之内联样式和样式表
95 0
react笔记之学习之内联样式和样式表
|
编解码 前端开发 JavaScript
手摸手带你实现一个时间轴组件
本文给大家带来一个时间轴的组件开发教程
765 0
|
前端开发
#yyds干货盘点 react笔记之学习之内联样式和样式表
#yyds干货盘点 react笔记之学习之内联样式和样式表
79 0
|
XML JavaScript 前端开发
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换
207 0
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换
|
Web App开发 前端开发
React 16.x折腾记 - (3) 结合Mobx实现一个比较靠谱的动态tab水平菜单,同时关联侧边栏
动态tab水平菜单,这个需求很常见,特别是对于后台管理系统来说 实现的思路有点绕,有更好的姿势请留言,谢谢阅读。
307 0