- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当尝试在可滚动的 div 中垂直固定 SVG 项目时,将其 y 坐标设置为 scrollTop 属性,如以下示例所示:
var container = document.getElementById('container');
var fixedText = document.getElementById('fixed-text');
fixedText.setAttribute('y', container.scrollTop + 50);
container.addEventListener('scroll', function() {
fixedText.setAttribute('y', container.scrollTop + 50);
});
div {
border: 1px solid black;
width: 300px;
height: 300px;
margin: auto;
overflow: auto;
}
svg {
width: 400px;
height: 2000px;
}
text {
text-anchor: middle;
}
<div id="container">
<svg>
<text id="fixed-text" x="200" y="50">Fixed text vertically, but not horizontally</text>
</svg>
</div>
JSFiddle:https://jsfiddle.net/fr4top2g/10/
SVG 项目已在 Chrome 中正确修复,但我在使用 Firefox 时遇到问题,该项目似乎在更新 div 内的 View 框之前定位,导致它在屏幕上振荡,而不是固定为预期的。 (这在使用鼠标滚轮滚动时尤为明显)。
这个问题可能是由 Chrome 和 Firefox 中不同的滚动处理方式引起的,您有什么简单的解决方案吗?
注意 1:由于该项目可能太宽而无法放入 div,因此它还必须是可水平滚动的,这意味着如果解决方案不涉及将 SVG 项目从其容器可滚动 div 中取出会更简单.
注2:请注意,如果我们在Firefox中打开网络控制台,点击SVG项目,然后用鼠标滚轮垂直滚动,这个问题似乎由于某种原因得到了解决。
注意 3:我已经在这个项目中使用 D3.js,所以任何涉及它的解决方案都不会打扰我。我目前没有使用 JQuery,尽管如果我不得不这样做也是可能的。
注4:同样的问题出现在提供给这个主题的解决方案中:Fixing an element on Y axis, but scrolling with page on x axis?
提前感谢您的帮助。
最佳答案
Firefox 滚动管理与 DOM 元素更新异步完成,如本页所述:https://developer.mozilla.org/en-US/docs/Mozilla/Performance/Scroll-linked_effects
我终于设法修复了 SVG 项目,没有使用 Javascript,而是使用了一些 CSS,以及一个 SVG 外部对象:
#container {
border: 1px solid black;
width: 300px;
height: 300px;
margin: auto;
overflow: auto;
}
svg#outer-svg {
width: 400px;
height: 2000px;
}
text {
text-anchor: middle;
}
#inner-svg {
position: sticky;
top: 70px;
width: 400px;
height: 50px;
}
<div id="container">
<svg id="outer-svg">
<foreignObject id="foreign-object" width="100%" height="100%">
<body xmlns="http://www.w3.org/1999/xhtml">
<svg id="inner-svg">
<text x="200" y="30">Fixed text vertically, but not horizontally</text>
</svg>
</body>
</foreignObject>
</svg>
</div>
关于javascript - 修复垂直滚动时的 SVG 元素,Firefox 的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51140165/
如果附加了 'not-scroll' 类,我希望我的 body 不滚动,否则它应该正常工作。 我已经搜索这个问题两天了,但找不到任何适合我的解决方案。 我想要的是向 body 添加一个 class,并
我发现似乎是 iOS Safari 中的错误(我正在 iOS 8 上进行测试)。当绝对定位的 iFrame 漂浮在一段可滚动内容上方时,滚动 iFrame 也会滚动下面的内容。以下 HTML (ava
我有以下代码来显示一系列投资组合图片,这些图片以 SVG 格式存储在滚动 div 中: 在 Safari 中滚动使用两根手指或鼠标滚轮当光标位于 SVG 之一上时不起作用。 该页
我想用 javascript 做的是: 一旦你向下滚动页面,将#sidebar-box-fixed 的位置从 position: relative; 更改为定位:固定;。改回position:rela
我对 Elasticsearch 的滚动功能有点困惑。在 elasticsearch 中,每当用户在结果集上滚动时,是否可以每次调用搜索 API?来自文档 "search_type" => "scan
我试图做到这一点,以便当我向上或向下滚动页面时,它会运行不同的相应功能。我发现了一个类似的问题here但我已经尝试了他们的答案并且没有运气。 注意:此页面没有正常显示的滚动条。没有地方可以滚动。 bo
(C语言,GTK库) 在我的表单上,我有一个 GtkDrawingArea 小部件,我在上面使用 Cairo 绘制 GdkPixbufs(从文件加载)。我想要完成的是能够在窗口大小保持固定的情况下使用
最近我一直在尝试创建一个拉到(刷新,加载更多)swiftUI ScrollView !!,灵感来自 https://cocoapods.org/pods/SwiftPullToRefresh 我正在努
我正在开发一个应用程序,其中有两个带有可放置区域的列表和一个带有可拖动项目的侧面菜单。 当我滚动屏幕时,项目的位置困惑。 我试图在谷歌上寻找一些东西,最后得到了这个问题:jQuery draggabl
我在 UIWebView 中加载了一个 HTML 表单,而我的 UIWebView 恰好从 View 的中间开始并扩展。我必须锁定此 webView 不滚动并将其放在 ScrollView 之上以允许
如何在每个元素而不是整个元素上应用淡入淡出(与其高度相比)? HTML: CSS: * { padding: 0; margin: 0; box-sizing: border
我想使用带有垂直轴的 PageView 并使用鼠标滚动在页面之间移动,但是当我使用鼠标滚动时页面不滚动...仅页面单击并向上/向下滑动时滚动。 有什么办法吗? 我想保留属性 pageSnapping:
我制作这个程序是为了好玩,但我被卡住了,因为程序在屏幕外运行。如何在不完全更改代码的情况下实现滚动条。 public static void main(String args[]) throws IO
我想使用带有垂直轴的 PageView 并使用鼠标滚动在页面之间移动,但是当我使用鼠标滚动时页面不滚动...仅页面单击并向上/向下滑动时滚动。 有什么办法吗? 我想保留属性 pageSnapping:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
使用 jquery 技术从 css-tricks.com 获得滚动/跟随侧边栏,如果您不知道我在说什么,这里是代码: $(function() { var $sidebar = $
我是 jQuery Mobile 新手。我需要向我的应用程序添加 Facebook 滑动面板功能。 我经历了 sliding menu panel ,它工作正常,但我在菜单面板中的内容超出了窗口大小,
有没有办法在 js 或 jQuery 或任何其他工具中检测 ctrl + 滚动。我正在尝试执行一些动态布局代码,我需要检测不同分辨率下的屏幕宽度,我通过使用 setTimeout() 的计时器实现了这
我有一部分html代码:
我想控制 RichTextBox 滚动,但在控件中找不到任何方法来执行此操作。 这样做的原因是我希望当鼠标光标位于 RichTextBox 控件上时鼠标滚轮滚动有效(它没有事件焦点:鼠标滚轮事件由表单
我是一名优秀的程序员,十分优秀!