marker-mid

Baseline 已广泛支持

该特性已非常成熟,可在多种设备和浏览器版本上使用。自 2017 年 4 月以来,它已在各大浏览器上可用。

marker-mid CSS 属性指向将在元素路径的中间顶点上绘制的标记;也就是说,在其起始顶点和结束顶点之间的每个顶点上绘制。该标记必须使用 SVG <marker> 元素定义,并且只能通过 <url> 值引用。此 CSS 属性的值会覆盖 SVG 中 marker-mid 属性的任何值。

每个标记指向的方向定义为前一个路径段末端的方向与后一个路径段起始方向之间的一半方向。这可以认为是两个路径方向定义的向量的叉积。

注意: marker-mid 属性仅对可以使用 SVG 标记的元素有效。有关列表,请参阅 marker-mid

语法

css
marker-mid: none;
marker-mid: url("markers.svg#arrow");

/* Global values */
marker-mid: inherit;
marker-mid: initial;
marker-mid: revert;
marker-mid: revert-layer;
marker-mid: unset;

none

这意味着在元素路径的每个中间顶点处都不会绘制标记。

<marker-ref>

一个 <url>,引用由 SVG <marker> 元素定义的标记,将在元素路径的每个中间顶点处绘制。如果 URL 引用无效,则不会在路径的中间顶点处绘制标记。

正式定义

初始值none
应用于svg 中的 <circle><ellipse><line><path><polygon><polyline><rect> 元素
继承性
计算值按指定,但 <url> 值变为绝对路径
动画类型离散

正式语法

marker-mid = 
none |
<marker-ref>

<marker-ref> =
<url>
此语法反映了 CSS 规范 中的最新标准。并非所有浏览器都可能已实现所有部分。有关支持信息,请参阅浏览器兼容性

示例

html
<svg viewBox="0 0 240 120" xmlns="http://www.w3.org/2000/svg">
  <defs>
    <marker
      id="triangle"
      viewBox="0 0 10 10"
      markerWidth="10"
      markerHeight="10"
      refX="1"
      refY="5"
      markerUnits="strokeWidth"
      orient="auto">
      <path d="M 0 0 L 10 5 L 0 10 z" fill="red" />
    </marker>
  </defs>
  <polyline
    id="test"
    fill="none"
    stroke="black"
    points="20,100 40,60 70,80 100,20 130,10 150,10 170,20 170,100 120,100" />
</svg>
css
polyline#test {
  marker-mid: url("#triangle");
}

规范

规范
Scalable Vector Graphics (SVG) 2
# MarkerMidProperty

浏览器兼容性

另见