10

从各种来源我收集到 svg 中的 vector-effect="non-scaling-stroke" 应该在当前版本的 Opera、Firefox 和 Chrome 中工作。(不确定IE10)。

但是我只能让它在 Opera 和 Firefox 中工作,然后只有当它直接嵌入为图像时,如果它在 CSS 中缩放为背景图像,则它不起作用。

我的问题:

为什么不镀铬?

为什么不在背景图像中?

有没有一种标准方法可以在所有最新的浏览器中使用它?

一个小提琴的例子。

HTML:

<div><img src="http://dl.dropbox.com/u/60476509/close.svg" /></div>
<div><img id="one" src="http://dl.dropbox.com/u/60476509/close.svg" /></div>
<div id="two"></div>
<div id="three"></div>

CSS:

#one {
    width: 200px;
    height: 200px;
}

#two {
    background-image: url("http://dl.dropbox.com/u/60476509/close.svg");
    height: 100px;   /* native size */
    width: 100px;
    background-size: contain;        
}
#three {
    background-image: url("http://dl.dropbox.com/u/60476509/close.svg");
    height: 200px;
    width: 200px;
    background-size: cover;        
}    
4

2 回答 2

4

我不知道幕后发生了什么,但有一个更简单的解决方案,至少对于内联 SVG(不确定背景)。改变:

<img src="svg-source.svg"/>

到:

<object type="image/svg+xml" data="svg-source.svg"></object>

此外,您需要确保已为 svg 文档viewBox定义

根据这个答案object,无论如何使用是更好的做法。是一篇不错的博客文章,建议(为了跨浏览器兼容性):

<object type="image/svg+xml" data="svg-source.svg">
    <img src="png-version.png"/>
</object>

我没有测试后一个选项,但如果它有效,它比这个解决方案简单得多。

编辑:我发现作为嵌入式对象,SVG 会干扰“悬停”和“点击”事件,所以我最终屈服并决定我必须完全嵌入 SVG。但我对粘贴每一个都没有兴趣,所以我的 javascript 文件顶部有以下内容(我使用的是 JQuery):

$(document).ready(function()
{
    $('.deferred-load').deferredLoad();
}
$.fn.deferredLoad = function()
{
    $(this).each(function()
    {
        $(this).load($(this).attr('data-load'));
    });
}

现在<img src="svg.svg"/>我可以写而不是<div class="deferred-load" data-load="svg.svg"></div>.

当然,这在没有启用 Javascript 的情况下是行不通的。但这比粘贴所有丑陋的 XML 要好得多。

于 2013-06-23T04:34:57.810 回答
0

在幕后,UA 需要绘制 SVG,然后将其转换为位图以创建图像(包括背景图像)。最简单的绘制方法是重用非图像渲染代码,然后缩放位图,但是当缩放位图时,它会变得模糊并且也不能正确渲染非缩放笔画。正确的方法是弄清楚您最终想要绘制位图的大小,并告诉 SVG 绘图代码在其中进行绘制。

这个错误刚刚在 Firefox 中得到修复。您可以在今天尝试Nightly或等待 9 月的发布。

于 2013-06-23T07:50:43.880 回答