Safari不尊重填充

时间:2016-06-16 10:29:07

标签: css svg safari

我目前正在开发一个页面,其上有一系列svgs,使用(坦率地说是惊人的)d3.js动态创建。

一切都很好,除了我在Safari中遇到一个奇怪的问题(Mac OS X上的版本9.1.1(10601.6.17)(Yosemite,在El Capitan上可重复使用最新的Safari 9.1))因此事情未对齐。我有两个svgs紧挨着彼此,所有意图和目的都有相同的边距,填充等定义,但其中一个正确(14px的填充顶部),而另一个(理论上也与14px padding-top)似乎完全忽略了这个填充并且高出14px。从下图中可以看出,我已经使用了Safari内置的开发工具,并且填充似乎已经正确定义,它只是决定不关心。

left svg (correct)

比较: right svg (incorrect)

值得注意的是,这个问题与我所拥有的svg-pair一样重复,所以它不仅仅发生在一个实例中(在这两个图像中你都可以看到同样的现象反复出现) )。

另一个奇怪/有趣的元素是,当我缩小(使用⌘+⇧+ - )时,问题似乎就解决了。这仅发生在默认缩放级别。

非常感谢任何帮助/指针。我不会以任何有意义的方式形容自己是一名前端开发者,因为必要,我真的这样做,所以我完全有可能做一些非常愚蠢的事情。

这一切都适用于Chrome。

1 个答案:

答案 0 :(得分:2)

在跟进olivier的建议之后,我正在修复一些非整数宽度/高度,但遗憾的是,这些都不起作用,但在这样做时我正在查看填充并决定尝试调整它。长话短说,显然Safari正在投掷一个合适的因为svgs试图完美触摸。左侧svg上的填充权为0,右侧svg上的填充左侧为0似乎是个问题。修复是将两个填充设置为0.02px(似乎是没有它给我带来麻烦的最低限度)。这在两个svgs之间留下了非常微妙的缝隙,但显然这是对未对齐它们的巨大改进。