我正在使用 svg 绘制折线图,并且需要对其应用渐变。对于每一行,我使用一个路径元素并将笔画设置为我的线性渐变元素之一。
这适用于除纯水平线之外的所有内容 - 在这种情况下,我的线上根本没有颜色。
我做了一个小提琴来显示问题:http: //jsfiddle.net/b6EQT/
<svg>
<defs>
<linearGradient id="grad" x1="0%" x2="100%" y1="0%" y2="0%">
<stop class="" offset="0%" style="stop-color: red;"></stop>
<stop class="" offset="33%" style="stop-color: yellow;"></stop>
<stop class="" offset="66%" style="stop-color: pink;"></stop>
<stop class="" offset="100%" style="stop-color: blue"></stop>
</linearGradient>
</defs>
<-- Gradient not applied -->
<path stroke="url(#grad)" d="M20,20L400,20" style="stroke-width: 10px;"></path>
<-- Gradient applied since height of 1px -->
<path stroke="url(#grad)" d="M20,40L400,41" style="stroke-width: 10px;"></path>
<-- Gradient applied because of fake initial "move to" -->
<path stroke="url(#grad)" d="M-1,-1,M20,60L400,60" style="stroke-width: 10px;"></path>
</svg>
没有出现纯水平线(第一条路径),而第二条(y 的轻微变化)出现了。
我尝试了一些小技巧来启动它 - 在开始时放置一个假的 M-1,-1,这似乎可以解决 IE 和 Chrome 中的问题,但不能解决 Firefox。这让我觉得我在理解 SVG 渐变和路径时遗漏了一些东西。有没有办法让它工作?