在CSS中,是否可以使用calc()
函数来操作十六进制颜色值?
在以下CSS片段中,我想使用--enable
变量在background-color
属性的两个十六进制颜色值之间切换,这些颜色值为 MyBtnStyle : --enable-color
和--disable-color
。
当使用rgb(r,g,b)
颜色格式时,可以通过使用calc()
计算每个颜色组成部分来实现这一点,但是我更喜欢直接在十六进制颜色值之间进行切换。
:root {
--enable: 0;
--disable-color: #ff0000;
--disable-r: 255;
--disable-g: 0;
--disable-b: 0;
--enable-color: #00ff00;
--enable-r: 0;
--enable-g: 255;
--enable-b: 0;
}
.MyBtnStyle {
width: 100%;
height: 100%;
text-align: center;
border: 2px;
margin: 1px 1px;
color: black;
padding: 1px 1px;
background-color: calc(var(--enable-color)*var(--enable) + var(--disable-color)*(1 - var(--enable)));
}
/* this works */
/* rgb( calc(var(--enable-r)*var(--enable) + var(--disable-r)*(1 - var(--enable)) ),
calc(var(--enable-g)*var(--enable) + var(--disable-g)*(1 - var(--enable)) ),
calc(var(--enable-b)*var(--enable) + var(--disable-b)*(1 - var(--enable)) )) */