::-webkit-meter-inner-element

非標準:此特性未標準化。我們不建議在生產環境中使用非標準特性,因為它們瀏覽器支援有限,並且可能會更改或被移除。但是,在沒有標準選項的特定情況下,它們可以是合適的替代方案。

::-webkit-meter-inner-element 是一個 WebKit 專有的 CSS 偽元素,用於選擇和應用樣式到 <meter> 元素的外部容器元素。額外標記可將 meter 元素渲染為只讀。

語法

css
::-webkit-meter-inner-element {
  /* ... */
}

示例

這僅適用於基於 WebKit 和 Blink 的瀏覽器,例如 Safari、Chrome 以及基於 Chromium 的 Edge 版本。

HTML

html
Normal: <meter min="0" max="10" value="6">Score 6/10</meter>
<br />
Styled: <meter id="styled" min="0" max="10" value="6">Score 6/10</meter>

CSS

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-inner-element {
  -webkit-appearance: inherit;
  box-sizing: inherit;
  border: 1px dashed #aaaaaa;
}

JavaScript

js
// 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");
}

結果

規範

不屬於任何標準。

瀏覽器相容性

另見

WebKit/Blink 用於樣式化 <meter> 元素其他部分的偽元素如下: