标记

**marker** CSS 属性指向将在元素路径的第一个、中间和最后一个顶点上绘制的标记;也就是说,在所有顶点上。该标记必须使用 SVG <marker> 元素定义,并且只能使用 url() 值引用。CSS 属性的值将覆盖 SVG 中 marker-startmarkermarker-end 属性的任何值。

对于许多支持标记的形状,第一个和最后一个顶点位于同一位置:例如,<rect> 的左上角。在这样的形状中,如果定义了第一个和最后一个标记,则将在该点绘制两个标记,尽管它们可能不会指向相同的方向。

对于中间顶点,每个标记指向的方向定义为前一个路径段结束时的方向与下一个路径段开始时的方向之间的中间方向。可以将其视为由两个路径方向定义的向量的叉积。

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

语法

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

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

none

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

<marker-ref>

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

正式定义

数据库中未找到值!

正式语法

marker = 
none |
<marker-ref>

<marker-ref> =
<url>

<url> =
<url()> |
<src()>

<url()> =
url( <string> <url-modifier>* ) |
<url-token>

<src()> =
src( <string> <url-modifier>* )

示例

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="#f00" />
    </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: url(#triangle);
}

规范

规范
可缩放矢量图形 (SVG) 2
# MarkerShorthand

浏览器兼容性

BCD 表仅在浏览器中加载

另请参阅