React 切换主题颜色

1.src目录下创建content.ts

代码

import { createContext, useContext, useMemo } from 'react';
export enum Theme {
    Light = 'light',
    Dark = 'dark',
}

export const DEFAULT_THEME = Theme.Light;

//  设置主题颜色
export const ThemeContext = createContext<[Theme | string, (theme: Theme | string) => void]>([
    '',
    () => null,
]);

export function useThemeContext() {
    return useContext(ThemeContext);
}

export function useTheme(): [string, (theme: Theme | string) => void] {
    const [contextTheme, setContextTheme] = useThemeContext();

    const localTheme = useMemo(() => contextTheme ?? DEFAULT_THEME, [contextTheme]);
    const setTheme = (theme: Theme | string) => {
        setContextTheme(theme);
    };

    return [localTheme, setTheme];
}

2.src/创建index.css

代码

@tailwind base;
@tailwind components;
@tailwind utilities;

html,
body,
#root {
	height: 100%;
	width: 100%;
	position: relative;
}

/* :root {
	--success-light: theme('colors.success.light');
	--success-dark: theme('colors.success.dark');
	--warning-light: theme('colors.warning.light');
	--warning-dark: theme('colors.warning.dark');
	--issue-light: theme('colors.issue.light');
	--issue-dark: theme('colors.issue.dark');
	--steel: theme('colors.steel.DEFAULT');
	--steel-dark: theme('colors.steel.dark');
} */

/*---------------- 主题颜色 ----------------------*/
.light {
	--theme-text: red;
	
}
.dark {
	--theme-text: #06061a;
}

.defined-hero-darkest {
	color: var(--theme-text);
}

3.src/compoonents创建theme文件

3.1 => themeProvider.tsx
 

import React, { type ReactNode, useMemo, useState } from 'react';

import { ThemeContext, Theme } from '@/context';


export default function ThemeProvider({ children }: { children: ReactNode }): ReactNode {
	const [theme, setTheme] = useState<Theme | string>(Theme.Light);
	const localTheme = useMemo(() => {
		const storageTheme = localStorage.getItem('theme');
		if (storageTheme && storageTheme != 'undefined') {
			setTheme(storageTheme);
			return storageTheme;
		}
		return theme;
	}, [theme]);
	return (
		<ThemeContext.Provider
			value={[
				localTheme,
				(param: Theme | string) => {
					localStorage.setItem('theme', param);
					setTheme(param);
				},
			]}
		>
			<div className={localTheme}>{children}</div>
		</ThemeContext.Provider>
	);
}

3.2 => ThemeSelect.tsx

import { useTheme,Theme } from '@/context';
export default function ThemeSelect() {
	const [localTheme, setTheme] = useTheme();
	return (
		<div className={'theme-select-wrap'}>
			<div
				className='defined-hero-darkest'
				onClick={() => {
					setTheme(localTheme === Theme.Light ? Theme.Dark : Theme.Light);
				}}
			>
				{localTheme === 'light' ? <div >light</div> : <div>dark</div>}
			</div>
		</div>
	);
}

4.main.tsx中导入index.css,ThemeProvider


代码

import React from 'react';
import ReactDOM from 'react-dom/client';
import App from './App.tsx';
import "./index.css"

import { BrowserRouter } from 'react-router-dom';
import ThemeProvider from '@/components/theme/themeProvider';


ReactDOM.createRoot(document.getElementById('root')!).render(
  <React.StrictMode>
    <BrowserRouter>
    <ThemeProvider>
    <App />
    </ThemeProvider>
     
    </BrowserRouter>
  </React.StrictMode>,
)

5.注册切换主题色组件

6.在任意标签添加以定义样式类名如defined-hero-darkest


注:!!!
.light.dark内部才生效


使用某些组件库时不在.light.dark内部不生效


只需在外部添加一个localTheme(light.dark)即可

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值