图标字体颜色可通过CSS变量统一管理,定义--icon-color等变量于:root,用color:var(--icon-color)应用至.icon或.fa类,并支持hover、disabled状态及深色模式动态切换,注意避免内联样式覆盖和fill属性误用。
图标字体(如 Font Awesome、Iconfont 等)的颜色可以通过 CSS 变量统一管理,核心思路是:把颜色值抽离为自定义属性(--icon-color),在图标选择器中复用该变量,后续只需修改变量值即可全局生效。
在 :root 或某个公共作用域中声明变量,便于全站或组件级复用:
:root {
--icon-color: #333;
--icon-color-hover: #007bff;
--icon-color-disabled: #ccc;
}
图标字体通常通过类名(如 .fa、.icon)或伪元素(如 ::before)渲染,需确保样式命中:
.icon, .fa { color: var(--icon-color); }
.icon::before { color: var(--icon-color); }
.icon:hover { color: var(--ic
on-color-hover); }
.icon.disabled { color: var(--icon-color-disabled); }
利用 CSS 变量的可继承与可覆盖特性,轻松实现深色模式、品牌主题等:
@media (prefers-color-scheme: dark) { :root { --icon-color: #eee; } }
.sidebar { --icon-color: #2c3e50; } —— 其内部所有 .icon 会自动继承新值
确保变量真正生效,注意以下细节:
--c1、--mainColor 这类模糊命名color 内联样式或 class 覆盖,否则会忽略变量fill(如 SVG 字体或内联 SVG),需用 fill: var(--icon-color) 替代 color