I want to invert colors on the whole web page, except one button. I'm using below code to invert colors on whole page:
html {
scroll-behavior: smooth;
background-color: var(--bgColor);
filter: invert(var(--invertColors));
-moz-filter: invert(var(--invertColors));
-o-filter: invert(var(--invertColors));
-ms-filter: invert(var(--invertColors));
}
Note that --invertColors
is global CSS variable and is set to either 1
or 0
.
The problem starts with that: I have one html object that I don't want the filter to be applied:
<button onclick="backgroundColors_Yellow()" class="background-yellow-button" >A</button>
And the corresponding CSS section:
.background-yellow-button {
font-size: 25px;
color: #fff70b;
cursor: pointer;
font-family: Raleway, sans-serif;
background-color: #111;
padding: 2px 8px 2px 8px;
border-radius: 50%;
border: 2px solid;
border-color: #fff70b;
outline: none;
font-weight: 600;
}
I have tried replacing CSS html section with this code below, but it does not work (still everything is changing including that button):
html:not(.background-yellow-button) {
scroll-behavior: smooth;
background-color: var(--bgColor);
filter: invert(var(--invertColors));
-moz-filter: invert(var(--invertColors));
-o-filter: invert(var(--invertColors));
-ms-filter: invert(var(--invertColors));
}
I have tried adding an id tag to that button id="button-y"
, and selecting html section with html:not(#button-y)
but it doesn't work either way.
Thanks for any tips, Mateusz.
#fff;
(white) because black minus black is zero and so is white minus white, so white will go to black, but black will not go to white.