首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何设置HTML5 <meter>标签的样式

如何设置HTML5 <meter>标签的样式
EN

Stack Overflow用户
提问于 2011-11-11 21:46:36
回答 6查看 34.7K关注 0票数 26

我想知道如何设置新的<meter>标签的样式。

代码语言:javascript
复制
<meter value=80 min=0 max=100>
  80/100
</meter>

我只想更改背景颜色和值颜色,但我找不到正确的CSS属性。对于基于webkit的浏览器,我发现了以下内容:

代码语言:javascript
复制
meter::-webkit-meter-horizontal-bar {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#DDD), color-stop(0.2, #EEE), color-stop(0.45, #CCC), color-stop(0.55, #CCC), to(#DDD));
}
Pseudo element
meter::-webkit-meter-horizontal-optimum-value {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#AD7), color-stop(0.2, #CEA), color-stop(0.45, #7A3), color-stop(0.55, #7A3), to(#AD7));
}
Pseudo element
meter::-webkit-meter-horizontal-suboptimal-value {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#FE7), to(#FE7), color-stop(0.2, #FFC), color-stop(0.45, #DB3), color-stop(0.55, #DB3));
}
Pseudo element
meter::-webkit-meter-horizontal-even-less-good-value {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#F77), to(#F77), color-stop(0.2, #FCC), color-stop(0.45, #D44), color-stop(0.55, #D44));
}
Pseudo element
meter::-webkit-meter-vertical-bar {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 100% 0%, from(#DDD), to(#DDD), color-stop(0.2, #EEE), color-stop(0.45, #CCC), color-stop(0.55, #CCC));
}
Pseudo element
meter::-webkit-meter-vertical-optimum-value {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 100% 0%, from(#AD7), to(#AD7), color-stop(0.2, #CEA), color-stop(0.45, #7A3), color-stop(0.55, #7A3));
}
Pseudo element
meter::-webkit-meter-vertical-suboptimal-value {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 100% 0%, from(#FE7), to(#FE7), color-stop(0.2, #FFC), color-stop(0.45, #DB3), color-stop(0.55, #DB3));
}
Pseudo element
meter::-webkit-meter-vertical-even-less-good-value {
-webkit-appearance: meter;
background: -webkit-gradient(linear, 0% 0%, 100% 0%, from(#F77), to(#F77), color-stop(0.2, #FCC), color-stop(0.45, #D44), color-stop(0.55, #D44));
}

在哪里可以找到适用于基于gecko的浏览器(Firefox)、Opera和IE的正确CSS属性?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2013-02-04 08:54:40

我使用以下代码在Webkit浏览器中设置了一个漂亮的细微渐变样式:

代码语言:javascript
复制
meter { -webkit-appearance: none; } //Crucial, this will disable the default styling in Webkit browsers

meter::-webkit-meter-bar {
    background: #FFF;
    border: 1px solid #CCC;
}

meter::-webkit-meter-optimum-value {
    background: #87C7DE;
    background: -moz-linear-gradient(top, #a1d4e6 0%, #6bb4d1 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #a1d4e6), color-stop(100%, #6bb4d1));
    background: -webkit-linear-gradient(top, #a1d4e6 0%, #6bb4d1 100%);
    background: -o-linear-gradient(top, #a1d4e6 0%, #6bb4d1 100%);
    background: -ms-linear-gradient(top, #a1d4e6 0%, #6bb4d1 100%);
    background: linear-gradient(to bottom, #a1d4e6 0%, #6bb4d1 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#a1d4e6', endColorstr='#6bb4d1',GradientType=0);
}

然而,CSS-Tricks recommends the following HTML代码的Chris Coyier:

代码语言:javascript
复制
<div class="meter">
    <span style="width: 25%"></span>
</div>

..。而不是HTML5 <meter><progress>标签。在这个时间点(2013年2月),我同意他的观点:

更糟糕的是,不同的浏览器,甚至是不同的WebKit浏览器,情况都有很大的不同。伪元素的工作也不一致。我不想让事情像这样悬而未决,但这真的是另一个话题了。可以肯定地说,对于这些特定的进度条,div/span就是目前的解决方案。

浏览器似乎还没有准备好接受用于<meter><progress>的新的HTML5标准标记。话虽如此,我建议人们克服直奔未来的渴望,而更愿意去寻找视觉上有效的东西,直到下一步通知。我还应该提到,在当前时间点,这些标记的current browser support为53%……这对我来说不值得,但我会让您的项目自行决定。

票数 14
EN

Stack Overflow用户

发布于 2019-05-16 02:24:46

以下是2019年的跨浏览器解决方案:

代码语言:javascript
复制
meter {
  --background: #dadada;
  --optimum: forestgreen;
  --sub-optimum: gold;
  --sub-sub-optimum: crimson;

  /* The gray background in Firefox */
  background: var(--background);
  display: block;
  margin-bottom: 1em;
  width: 100%;
}

/* The gray background in Chrome, etc. */
meter::-webkit-meter-bar {
  background: var(--background);
}

/* The green (optimum) bar in Firefox */
meter:-moz-meter-optimum::-moz-meter-bar {
  background: var(--optimum);
}

/* The green (optimum) bar in Chrome etc. */
meter::-webkit-meter-optimum-value {
  background: var(--optimum);
}

/* The yellow (sub-optimum) bar in Firefox */
meter:-moz-meter-sub-optimum::-moz-meter-bar {
  background: var(--sub-optimum);
}

/* The yellow (sub-optimum) bar in Chrome etc. */
meter::-webkit-meter-suboptimum-value {
  background: var(--sub-optimum);
}

/* The red (even less good) bar in Firefox */
meter:-moz-meter-sub-sub-optimum::-moz-meter-bar {
  background: var(--sub-sub-optimum);
}

/* The red (even less good) bar in Chrome etc. */
meter::-webkit-meter-even-less-good-value {
  background: var(--sub-sub-optimum);
}
代码语言:javascript
复制
<label>
  Optimum
  <meter value=80 min=0 low=30 high=60 max=100 optimum=80>
    80/100
  </meter>
</label>

<label>
  Sub-optimum
  <meter value=80 min=0 low=30 high=60 max=100 optimum=50>
    80/100
  </meter>
</label>

<label>
  Sub-sub-optimum
  <meter value=80 min=0 low=30 high=60 max=100 optimum=20>
    80/100
  </meter>
</label>

请注意,仪表的未填充(灰色)部分使用Chrome中的::-webkit-meter-bar设置样式,而firefox使用::-moz-meter-bar表示已填充的(绿色、黄色、红色)部分,并在meter元素下设置未填充部分的样式。

还要注意,火狐在meter元素上有伪选择器来区分最优值和次优值(:-moz-optimal:-moz-sub-optimal:-moz-sub-sub-optimal;然后您只需设置适当伪选择器的::-moz-meter-bar伪子元素的样式),而Chrome则允许您为此设置不同的伪元素样式(分别为::-webkit-meter-optimum-value::-webkit-meter-suboptimum-value::-webkit-meter-even-less-good-value )。

这里有一个链接,解释了这些带前缀的伪元素的含义。https://scottaohara.github.io/a11y_styled_form_controls/src/meter/

票数 12
EN

Stack Overflow用户

发布于 2013-06-19 06:14:35

以下是FireFox的规则。我在Firefox检查器中包含了一个屏幕截图,告诉你在哪里可以找到规则。

代码语言:javascript
复制
::-moz-meter-bar {
  /* Block styles that would change the type of frame we construct. */
  display: inline-block ! important;
  float: none ! important;
  position: static ! important;
  overflow: visible ! important;

  -moz-appearance: meterchunk;
  height: 100%;
  width: 100%;
}

:-moz-meter-optimum::-moz-meter-bar {
  /* green. */
  background: -moz-linear-gradient(top, #ad7, #ad7, #cea 20%, #7a3 45%, #7a3 55%);
}
:-moz-meter-sub-optimum::-moz-meter-bar {
  /* orange. */
  background: -moz-linear-gradient(top, #fe7, #fe7, #ffc 20%, #db3 45%, #db3 55%);
}
:-moz-meter-sub-sub-optimum::-moz-meter-bar {
  /* red. */
  background: -moz-linear-gradient(top, #f77, #f77, #fcc 20%, #d44 45%, #d44 55%);
}

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8094835

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档