- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用 d3.js 动态设置嵌套 svg,即嵌套在封闭 svg 中的内部 svg。 d3.behavior.zoom()监听外部 svg 上的缩放事件并进行所需的转换。
除了 Internet Explorer (IE 11) 似乎在涉及内部 svg 的转换方面存在问题外,一切正常。 Firefox 和 Chrome 都按照预期的方式将内部 svg 剪裁到外部 svg 的视口(viewport)。然而,在 Internet Explorer 中,放大会正确应用转换,但似乎会忽略封闭 svg 的尺寸。内部 svg 的内容最终将显示在外部 svg 之外和其他 body 元素之上。外部 svg 的视口(viewport)似乎对内部 svg 没有裁剪效果。
我已经设置了一个 JSFiddle展示行为。
var zoom = d3.behavior.zoom()
.on("zoom", function () {
container.attr("transform",
"translate(" + d3.event.translate + ") " +
"scale(" + d3.event.scale + ")");
});
var container = d3.select("body")
.append("svg")
.attr("id", "svgcontainer")
.attr("width", 300)
.attr("height", 300)
.style("background-color", "#aaaaee")
.call(zoom)
.append("g");
var svg = container.append("svg")
.attr("width", 200)
.attr("height", 200)
.attr("x", 50)
.attr("y", 50);
svg.append("svg:circle")
.style("fill", "none")
.style("stroke", "red")
.style("stroke-width", "2px")
.attr("cx", 100)
.attr("cy", 100)
.attr("r", 50);
我错过了什么吗?是否有任何跨浏览器的解决方法?
最佳答案
很抱歉这个问题在您第一次发布时没有得到足够的重视:它实际上是一个简单的修复。只需设置 overflow
外部 SVG 上的属性为 hidden
.
那么,为什么您的代码在其他浏览器上能按预期工作?
因为他们默认设置了这个属性。 overflow
的初始值在 CSS 中是 visible
,但是 SVG specs要求任何可以采用 viewBox
的元素属性有 overflow:hidden
在浏览器的默认样式表中,根 SVG 元素的除外。其他浏览器将此异常解释为仅适用于 <svg>
。 .svg 文档的根元素。 Internet Explorer 还适用于将 HTML 文档中的顶级内联 SVG 视为根(因此具有 overflow: visible
)。
以下代码段演示了不同的行为。它在内嵌 SVG 内的嵌套 SVG 内使用圆圈。圆对于嵌套的 SVG 来说太大了,所以如果嵌套的 SVG 上隐藏了溢出(所有浏览器默认情况下都是如此),圆将被裁剪成正方形。嵌套的 SVG 发生偏移,部分位于外部 SVG 之外。如果溢出隐藏在外部 SVG 上,则嵌套 SVG 将被裁剪为矩形;如果可以看到溢出,您会看到方 block 伸出框架。
第一个 SVG 在外部 SVG 上使用默认溢出(对于 IE 不同),而其他 SVG 明确设置 overflow: hidden
或 overflow: visible
.
svg {
border: solid gray;
height: 100px;
width: 100px;
margin: 50px;
}
circle {
fill: royalBlue;
}
<svg>
<svg x="-50" y="-50" width="100" height="100" >
<circle r="100" cx="50" cy="50"/>
</svg>
</svg>
<svg style="overflow: hidden">
<svg x="-50" y="-50" width="100" height="100" >
<circle r="100" cx="50" cy="50"/>
</svg>
</svg>
<svg style="overflow: visible">
<svg x="-50" y="-50" width="100" height="100" >
<circle r="100" cx="50" cy="50"/>
</svg>
</svg>
可能应该为 SVG 2 澄清溢出行为或在 the SVG integration spec . Firefox 和 Blink/Webkit 浏览器之间关于内联 SVG 上的填充是否被视为“溢出”也存在差异。
关于javascript - 带有嵌套 svg 的 D3.js 缩放打破了 Internet Explorer 中的视口(viewport),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27985171/
我想使用 li 和 ul 制作一个多级下拉列表,以便显示我博客中按年和月排序的所有文章。我希望我的下拉菜单看起来像 Google Blogspot 下拉菜单: 这是我的 CSS 和 HTML 代码 u
我在 Win 7 64 机器上将 CodeBlocks 与 gcc 4.7.2 和 gmp 5.0.5 结合使用。开始使用 gmpxx 后,我看到一个奇怪的段错误,它不会出现在 +、- 等运算符中,但
我正在使用 tern 为使用 CodeMirror 运行的窗口提供一些增强的智能感知,它工作正常,但我遇到了一个问题,我想添加一些自定义“types”,可以这么说,这样下拉列表中它们旁边就有图标了。我
我正在尝试让我的 PC 成为 Android 2.3.4 设备的 USB 主机,以便能够在不需要实际“附件”的情况下开发 API。为此,我需要将 PC 设置为 USB 主机和“设备”(在我的例子中是运
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我在设置服务器方面几乎是个新手,但遇到了一个问题。我有一个 Ubuntu 16.04 VPS 并安装了 Apache2 和 Tomcat7。我正在为 SSL 使用 LetsEncrypt 和 Cert
我在一个基于谷歌地图的项目上工作了超过 6 个月。我使用的是 Google Maps API V1 及其开发人员 API key 。当我尝试发布应用程序时,我了解到 Google API V1 已被弃
我是 Python 的新手,所以如果我对一些简单的事情感到困惑,请原谅。 我有一个这样的对象: class myObject(object): def __init__(self):
这个问题已经有答案了: How can I access object properties containing special characters? (2 个回答) 已关闭 9 年前。 我正在尝
我有下面的 CSS。我想要的是一种流体/液体(因为缺乏正确的术语)css。我正在为移动设备开发,当我改变模式时 从纵向 View 到陆地 View ,我希望它流畅。现在的图像 在陆地 View 中效
我正在尝试使用可以接受参数的缓存属性装饰器。 我查看了这个实现:http://www.daniweb.com/software-development/python/code/217241/a-cac
这个问题在这里已经有了答案: Understanding slicing (36 个答案) 关闭 6 年前。 以a = [1,2,3,4,5]为例。根据我的直觉,我认为 a[::-1] 与 a[0:
mysqldump -t -u root -p mytestdb mytable --where=datetime LIKE '2014-09%' 这就是我正在做的事情,它会返回: mysqldum
我正在制作销售税计算器,除了总支付金额部分外,其他一切都正常。在我的程序中,我希望能够输入一个数字并获得该项目的税额我还希望能够获得支付的总金额,包括交易中的税金。到目前为止,我编写的代码完成了所有这
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许在 Stack Overflow 上提出有关通用计算硬件和软件的问题。您可以编辑问题,使其成为
我是否必须进行任何额外的设置才能让 apache-airflow 在任务失败时向我发送电子邮件。我的配置文件中有以下内容(与默认值保持不变): [email] email_backend = airf
这个问题在这里已经有了答案: What does the $ symbol do in VBA? (5 个回答) 3年前关闭。 使用返回字符串(如 Left)的内置函数有什么区别吗?或使用与 $ 相同
我有一个用VB6编写的应用程序,我需要使用一个用.NET编写的库。有什么方法可以在我的应用程序上使用该库吗? 谢谢 最佳答案 这取决于。您可以控制.NET库吗? 如果是这样,则可以修改您的库,以便可以
当我创建一个以 ^ 开头的类方法时,我尝试调用它,它给了我一个错误。 class C { method ^test () { "Hi" } } dd C.new.test; Too m
我已经使用 bower 安装了 angularjs 和 materialjs。 凉亭安装 Angular Material 并将“ngMaterial”注入(inject)我的应用程序,但出现此错误。
我是一名优秀的程序员,十分优秀!