2

我想通过内容属性bootstrap-style将 SVG 图像用作 CSS 精灵,如下所示:

i.rectangle-image {
  content: url(rectangle.svg);
}

这是我的 SVG:

<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100">
  <rect x="10" y="10" width="80" height="80"/>
</svg>

并提出 HTML:

<div><i class="rectangle-image"></i> Hello, world!</div>

我希望能够在我的应用程序中重新着色 SVG,例如让图标在某些位置显示为紫色,而在其他位置显示为白色。我知道我可以通过fill在标签上设置不同属性的三个不同的 SVG 文件(或数据 URI)来实现这一点<rect>,但我想知道是否有办法通过我的 HTML 中的 CSS 来做到这一点?

我尝试向选择器添加一个fill属性i.rectangle-image,但这不起作用。

我看过这个答案,这不是我想要的。他们建议在整个页面中嵌入 SVG,如果可能的话,我更愿意通过 CSS 来做到这一点content。有什么想法吗?我运气不好?

4

3 回答 3

4

如果您使用 CSS 内容工具,您基本上将 SVG 数据加载为图像。出于隐私原因,您不能使用外部 CSS 或 javascript 影响图像的显示方式。

如果要更改 SVG 数据的内容,要么必须通过<object>or<iframe>标记加载它,要么将其内联到 HTML 文件中。

于 2013-05-03T11:47:14.910 回答
0

赋予 SVG 透明度并使用 css 背景颜色填充背景怎么样?

@MMM 建议的解决方案看起来很棒:

<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
     width="13px" height="12.917px" viewBox="0 0 13 12.917" enable-background="new 0 0 13 12.917" xml:space="preserve">
       <polygon fill="#000000" points="6.504,0 8.509,4.068 13,4.722 9.755,7.887 10.512,12.357 6.504,10.246 2.484,12.357 3.251,7.887 0,4.722 4.492,4.068 "/>
       <script>
         document.getElementsByTagName("polygon")[0].setAttribute("fill", location.hash);
       </script>
</svg>

http://jsbin.com/usaruz/2/edit

http://codepen.io/Elbone/pen/fHCjs

于 2013-05-03T11:56:17.620 回答
0

您可以使用SVG图像编辑器工具在前端编辑颜色并复制代码并在您想要放置的地方使用它,这需要很短的时间..试试它肯定会奏效

于 2013-05-22T11:21:25.940 回答