css - 具有三种不同边框颜色的圆圈

标签 css svg border css-shapes

我有一个带有一种边框颜色的圆圈的 CSS:

.circle {
  border: 6px solid #ffd511;
  border-radius: 30px;
  -moz-border-radius: 30px;
  -webkit-border-radius: 30px;
  -khtml-border-radius: 30px;
  width: 30px;
  height: 18px;
  line-height: 20px;
  padding: 12px 6px;
  text-align: center;
}
<div class="circle">17</div>

看起来像这样:

circle with one border color

我应该如何更改 CSS 以具有三种边框颜色 - 就像在时钟上一样:

  • 从 0 到 4 种颜色 #1
  • 4 到 8 种颜色 #2
  • 8 到 12 种颜色 #3

我敢肯定,它是可能的,元素 <canvas> ,但我没有成功。

最佳答案

您可以使用 inline svg 实现分成 3 个部分的圆形边框使用:

这是一个例子:

svg{width:30%;height:auto;}
<svg viewbox="0 0 10 10">
  <defs>
    <circle id="circle" cx="5" cy="5" r="4" stroke-width="0.5" fill="transparent" />
  </defs>
  <use xlink:href="#circle" stroke="pink" stroke-dasharray="0,2.09,8.38,30" />
  <use xlink:href="#circle" stroke="green" stroke-dasharray="0,10.47,8.38,30" />
  <use xlink:href="#circle" stroke="orange" stroke-dasharray="2.09,16.75,6.3" />
</svg>

编辑

要在圆圈内添加文本,您可以使用 svg text element :

svg{width:30%;height:auto;}
<svg viewbox="0 0 10 10">
  <defs>
    <circle id="circle" cx="5" cy="5" r="4" stroke-width="0.5" fill="transparent" />
  </defs>
  <use xlink:href="#circle" stroke="pink" stroke-dasharray="0,2.09,8.38,30" />
  <use xlink:href="#circle" stroke="green" stroke-dasharray="0,10.47,8.38,30" />
  <use xlink:href="#circle" stroke="orange" stroke-dasharray="2.09,16.75,6.3" />
  <text x="5" y="6.5" text-anchor="middle" font-size="5">17</text>
</svg>

关于css - 具有三种不同边框颜色的圆圈,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37206635/

相关文章:

html - 是否有一个库可以在不受支持的浏览器上禁用该网站?

javascript - 如何获取元素的 CSS(% vs px)

javascript - 如何在自定义 highcharts 按钮中垂直居中文本

javascript - 管理 Backbone.js/SVG Web 应用程序中的布局?

iphone - 如何更改ProgressView边框颜色

jquery - "Dropdown Toggle"上的 Twitter Bootstrap "btn btn-block btn-lg btn-primary"?

html - 在 IE9 中为表格设置修复(卡住)标题时出现问题?

css - 在 css 或 svg 中创建圆形运动模糊

html - <sup> 当在带有文本装饰下划线的元素内给出时,在 chrome 中使用下划线

html - 平滑大小变化的边框