前端实现动态切换主题色-使用 css/less 动态更换主题颜色(换肤功能)或通过单击更改背景颜色
要实现前端动态切换主题色,可以使用CSS变量(CSS Custom Properties)或者LESS。以下是使用CSS变量的示例:
- 定义默认主题色和可切换主题色的CSS变量。
:root {
--primary-color: #3498db; /* 默认主题色 */
--primary-color-light: #2980b9; /* 亮色 */
--primary-color-dark: #295185; /* 暗色 */
}
body {
background-color: var(--primary-color); /* 使用主题色作为背景色 */
color: #fff; /* 文字颜色 */
}
/* 其他样式 */
- 添加函数来切换主题色。
function switchTheme(newColor) {
const root = document.documentElement;
root.style.setProperty('--primary-color', newColor);
root.style.setProperty('--primary-color-light', lighten(newColor, 10%));
root.style.setProperty('--primary-color-dark', darken(newColor, 10%));
}
// 示例:将主题色更改为蓝色
switchTheme('#3498db');
switchTheme
函数接受一个新的颜色值,然后更新CSS变量,从而实现换肤。这里使用了 lighten
和 darken
函数来创建相应的亮色和暗色,这些函数需要依赖于你的工具链或者颜色处理库。
注意:这里的 lighten
和 darken
函数是示例,你需要使用实际的颜色变亮和变暗函数,例如CSS的 hsl()
或 rgb()
函数来计算相应的颜色。
评论已关闭