前端主题切换的多种方式

动态link标签加载不同主题css

**原理:**提前准备好几套CSS主题样式文件,在点击切换主题时,创建link标签动态加载到head标签中,或者是动态改变link标签的href属性。
缺点:

动态加载样式文件,如果文件过大网络情况不佳的情况下可能会有加载延迟,导致样式切换不流畅

维护不便!

**优点:**实现了按需加载,提高了首屏加载时的性能且兼容性好

  1. 先创建主题css文件dark.csslight.css
  2. html中link引入
html 复制代码
<head>
	<link rel="stylesheet" href="./css/dark.css" >
	<link rel="stylesheet" href="./css/light.css" disable>
</head>
  1. 切换主题
typescript 复制代码
const themesCssSheet = [
	document.querySelector("link[data-theme='light']"),
	document.querySelector("link[data-theme='dark']"),
]
btn.addEventlistner("click",()=>{
	const dataTheme = btn.getAttribute("data-theme")
	themesCssSheet.forEach(theme=>{
		t.disable = theme.dataset.theme === dataTheme 
	})
})

提前引入不同主题的css样式,通过切换类名切换主题

  1. 定义好css样式
css 复制代码
/* light样式主题 */
body{
  color: #f90;
  background: #fff;
  --text-color:black
  --header-bg:orange
}
/* dark样式主题 */
.dark {
  color: #eee;
  background: #333;
  --text-color:#fff
  --header-bg:blue
}
  1. 点击切换主题时 js切换
typescript 复制代码
document.body.classList.toggle("dark")

css预编译器

scss 复制代码
$themes:(
	light:(
		textColor:black
		headerBg:orange
	),
	dark:(
		textColor:#fff
		headerBg:blue
	)
)
$currentTheme:light;
@mixin changeTheme(){
	@each $key,$value in $themes{
		$currentTheme:$key !global;
		html[data-theme='#{$key}'] & {
			@content;
		}
	}
}

@function getTextColor(){
	$currentThemeObj: map-get($themes,$curTheme);
	@return map-get($currentThemeObj,"textColor");
}
@function getHeaderBg(){
	$currentThemeObj: map-get($themes,$curTheme);
	@return map-get($currentThemeObj,"headerBg");
}

@function getThemeValue($key){
	$currentThemeObj: map-get($themes,$curTheme);
	@return map-get($currentThemeObj,$key);
}
.content{
	width:100%;
	height:100%;
	@changeTheme{
		textColor:getTextColor();
		headerBg:getHeaderBg();
	}
}

基于CSS变量(最优方式)

原理 :根据html元素标签的属性切换所使用的主题变量。
缺点 :IE兼容性不行(基本可以忽略)。
优点:便于维护,基本无需css参与

  1. 定义两套(多主体多套)变量
css 复制代码
:root{
	--text-color:black
	--header-bg:orange
	...
}
// 暗色主题
html[data-theme='dark']{
	--text-color:#fff
	--header-bg:blue
	...
}
  1. 在main.js项目入口文件导入该变量,便于组件使用
  2. 组件中主题相关的直接使用变量
  3. 主题切换时
typescript 复制代码
type Theme = "dark" | "light"
export const changeTheme = (theme:Theme )=>{
	document.documentElement.dataset.theme = theme
}

CSS变量+动态setProperty

  1. 定义变量
css 复制代码
:root{
	--text-color:black
	--header-bg:orange
	...
}
  1. 定义js更改属性值方法
typescript 复制代码
export const setCssVar = (prop: string, val: any, dom = document.documentElement) => {
  dom.style.setProperty(prop, val)
}
// 当样式改变
setCssVar('--text-color', color)

总结

还有其他方式(例如vue3 v-bind css,变量和类名结合),但是总体都大同小异。

相关推荐
天下皆白_唯我独黑17 分钟前
php 使用qrcode制作二维码图片
开发语言·php
学术头条20 分钟前
AI 的「phone use」竟是这样练成的,清华、智谱团队发布 AutoGLM 技术报告
人工智能·科技·深度学习·语言模型
准橙考典21 分钟前
怎么能更好的通过驾考呢?
人工智能·笔记·自动驾驶·汽车·学习方法
ai_xiaogui24 分钟前
AIStarter教程:快速学会卸载AI项目【AI项目管理平台】
人工智能·ai作画·语音识别·ai写作·ai软件
孙同学要努力29 分钟前
《深度学习》——深度学习基础知识(全连接神经网络)
人工智能·深度学习·神经网络
喵~来学编程啦1 小时前
【论文精读】LPT: Long-tailed prompt tuning for image classification
人工智能·深度学习·机器学习·计算机视觉·论文笔记
深圳市青牛科技实业有限公司1 小时前
【青牛科技】应用方案|D2587A高压大电流DC-DC
人工智能·科技·单片机·嵌入式硬件·机器人·安防监控
水豚AI课代表2 小时前
分析报告、调研报告、工作方案等的提示词
大数据·人工智能·学习·chatgpt·aigc
几两春秋梦_2 小时前
符号回归概念
人工智能·数据挖掘·回归
用户691581141653 小时前
Ascend Extension for PyTorch的源码解析
人工智能