marker-start

Baseline 已广泛支持

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

marker-start CSS 属性指向一个标记,该标记将绘制在元素路径的第一个顶点,即其起始顶点。该标记必须已使用 SVG <marker> 元素定义,并且只能通过 <url> 值引用。此 CSS 属性的值会覆盖 SVG 中 marker-start 属性的任何值。

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

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

语法

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

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

none

这意味着元素的路径的第一个顶点不会绘制任何标记。

<marker-ref>

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

正式定义

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

正式语法

marker-start = 
none |
<marker-ref>

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

示例

html
<svg viewBox="0 0 120 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" />
</svg>
css
polyline#test {
  marker-start: url("#triangle");
}

规范

规范
Scalable Vector Graphics (SVG) 2
# MarkerStartProperty

浏览器兼容性

另见