目前正在构建一个基于浏览器的SVG应用程序。在这个应用程序中,用户可以设置各种形状的样式和位置,包括矩形。

当我将笔画宽度应用到SVG矩形元素(比如1px)时,不同的浏览器会以不同的方式将笔画应用到矩形的偏移和插入。这被证明是很麻烦的,特别是当我试图计算一个矩形的外部宽度和视觉位置,并将其放置在其他元素旁边时。

例如:

Firefox添加了1px的插入(底部和左侧)和1px的偏移(顶部和右侧) Chrome添加了1px的插入(顶部和左侧),和1px的偏移(底部和右侧)

到目前为止,我唯一的解决方案是自己绘制实际的边界(可能是用路径工具),并将边界定位在描边元素的后面。但这种解决方案是一种令人不快的变通方法,如果可能的话,我宁愿不走这条路。

所以我的问题是,你能控制SVG的笔画宽度如何在元素上绘制吗?


当前回答

这招对我很管用:

.btn {
 border: 1px solid black;
 box-shadow: inset 0 0 0 1px black;
}

其他回答

我不知道这有多大帮助,但在我的情况下,我只是创建了另一个圆,只有边界,并将其“在”另一个形状。

这招对我很管用:

.btn {
 border: 1px solid black;
 box-shadow: inset 0 0 0 1px black;
}

我发现最简单的方法是将clip-path添加到circle中

添加clip-path = "圆()"

<circle id="circle" clip-path="circle()" cx="100" cy="100" r="100" fill="none" stroke="currentColor" stroke-width="5" />

然后stroke-width="5"将神奇地变成内5px笔画,绝对半径为100px。

这里是一个关于内边框矩形使用符号和使用的工作。

例如:https://jsbin.com/yopemiwame/edit?html,输出

SVG:

<svg>
  <symbol id="inner-border-rect">
    <rect class="inner-border" width="100%" height="100%" style="fill:rgb(0,255,255);stroke-width:10;stroke:rgb(0,0,0)">
  </symbol>
  ...
  <use xlink:href="#inner-border-rect" x="?" y="?" width="?" height="?">
</svg>

注意:一定要替换?用真正的价值。

背景:这样工作的原因是因为symbol通过用svg替换symbol并在shadow DOM中创建一个元素来建立一个新的视口。阴影DOM的svg随后链接到当前svg元素。注意,svg可以嵌套,并且每个svg都会创建一个新的视口,它会剪辑所有重叠的部分,包括重叠的边界。要想更详细地了解正在发生的事情,请阅读Sara Soueidan的这篇精彩文章。

您可以使用CSS样式的笔画和填充顺序。即先描边,后填充,得到想要的效果。

MDN油漆订购:https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/paint-order

CSS代码:

paint-order: stroke;