::-webkit-meter-optimum-value
Non-standard: This feature is non-standard and is not on a standards track. Do not use it on production sites facing the Web: it will not work for every user. There may also be large incompatibilities between implementations and the behavior may change in the future.
The ::-webkit-meter-optimum-value
CSS pseudo-element styles the <meter>
element when its value is inside the low-high range, or when the value is equivalent to the optimum value.
Green is the default color.
Syntax
::-webkit-meter-optimum-value {
/* ... */
}
Examples
This example will only work in browsers based on WebKit or Blink.
HTML
Normal:
<meter min="0" max="10" low="3" high="7" optimum="6" value="6">
Score 6/10
</meter>
<br />
Styled:
<meter id="styled" min="0" max="10" low="3" high="7" optimum="6" value="6">
Score 6/10
</meter>
CSS
body {
font-family: monospace;
}
.safari meter {
/* Reset the default appearance for Safari only */
/* .safari class is added via JavaScript */
-webkit-appearance: none;
}
#styled::-webkit-meter-optimum-value {
background: linear-gradient(to bottom, #7f7, #090 45%, #090 55%, #7f7);
height: 100%;
box-sizing: border-box;
}
JavaScript
// Safari requires <meter> elements to have an `appearance` of `none` for custom styling
// using `::-webkit-meter-*` selectors, but `appearance: none` breaks rendering on Chrome.
// Therefore, we must check if the browser is Safari-based.
const is_safari =
navigator.userAgent.includes("AppleWebKit/") &&
!navigator.userAgent.includes("Chrome/");
if (is_safari) {
document.body.classList.add("safari");
}
Result
Specifications
Not part of any standard.
Browser compatibility
See also
The pseudo-elements used by WebKit/Blink to style other parts of a <meter>
element are as follows: