使用base64 svg image作为css内容源

时间:2014-10-06 21:05:09

标签: css svg base64

我正在尝试使用css内容和图像(base64),但是当我加载页面时会像破坏的链接图像一样加载。

现在,我正在使用一个网站下载base64图像,这是我正在使用的CSS,它给了我破碎的图像:

.default:after{
    content: url('');
    position:absolute;
    width:100px;
    height:100px;
  }

如果我将“损坏的”基础64图像打开到新的铬标签中,则会产生错误:

  

此页面包含以下错误:

     第1行第10行的

错误:文档末尾的额外内容   下面是第一个错误的页面呈现。

现在,我从未使用过base64图像,但我必须做一些特别的事情,或者只是复制并粘贴自动生成的代码?

提前感谢您的帮助

** PS:我正在开发本地主机,我不知道它是否可能是原因。

2 个答案:

答案 0 :(得分:10)

使用这个简单的bash命令,您可以轻松地将SVG文件转换为CSS背景属性的base64 ecoded值:

echo "background: transparent url('data:image/svg+xml;base64,"$(openssl base64 < path/to/file.svg)"') no-repeat center center;"

在Mac OS X上测试过。 这样你也可以避免URL转移混乱。

请记住,编码SVG文件的base64会增加其大小,请参阅css-tricks.com blog post

答案 1 :(得分:8)

这就是它所说的,你最后编码了文件+一些额外的垃圾。

这似乎是我通过http://www.opinionatedgeek.com/dotnet/tools/Base64Encode/解码来删除垃圾然后使用相同网站进行编码而获得的正确编码。

PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx1c3RyYXRvciAxNi4wLjQsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOiA2LjAwIEJ1aWxkIDApICAtLT4NCjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DQo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkNhcGFfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IiB5PSIwcHgiDQoJIHdpZHRoPSIxNnB4IiBoZWlnaHQ9IjE2cHgiIHZpZXdCb3g9IjAgMCAxNiAxNiIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgMTYgMTYiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPHBhdGggZD0iTTgsMEMzLjU4MiwwLDAsMy41ODIsMCw4czMuNTgyLDgsOCw4czgtMy41ODIsOC04UzEyLjQxOCwwLDgsMHogTTksMTJjMCwwLjU1Mi0wLjQ0OCwxLTEsMXMtMS0wLjQ0OC0xLTFWNw0KCWMwLTAuNTUyLDAuNDQ4LTEsMS0xczEsMC40NDgsMSwxVjEyeiBNOCw1LjAxNmMtMC41NTIsMC0xLTAuNDQ4LTEtMWMwLTAuNTUyLDAuNDQ4LTEsMS0xczEsMC40NDgsMSwxQzksNC41NjgsOC41NTIsNS4wMTYsOCw1LjAxNnoNCgkiLz4NCjwvc3ZnPg==