Dex*_*Dex 5 html javascript css jquery
我想知道是否可能以及如何将鼠标滚轮/滚动事件(用户的滚动尝试)从header转移到container.
我有以下示例情况:
+------------+ +------------+|
| header | | header ||
+------------+ +------------+|
| || | ||
| || | ||
| container || | container ||
| || | ||
| || | ||
+------------+ +------------+|
situation 1 situation 2
Run Code Online (Sandbox Code Playgroud)
情境2是"传统"设置,其中可以滚动整个页面.当光标悬停标题时(即使它可能已修复),滚动尝试将传递给body/html.由于容器溢出body/html,如果用户旋转他/她的鼠标滚轮,容器将移动/滚动.由于标题是固定的,它将保持在相同的位置.
情况1是我的测试设置.容器的内容溢出容器,这将导致容器显示滚动条.现在我希望容器在用户的光标悬停在标题上并且用户旋转他/她的滚轮时也滚动.
情况的一个方面1
我创造了另一个小提琴来展示我的进步,这可能是解决方案,但我无法让它发挥作用.这可能会激励其他人获得实际的解决方案:)我得到错误:( (index):69 Uncaught InvalidStateError: Failed to execute 'dispatchEvent' on 'EventTarget': The event is already being dispatched.
现在它只是chrome中的滚动事件)
这与我预期的解决方案最接近,该解决方案基于"其他解决方案2".感谢Maksym Stepanenko的研究,它似乎还不可能.我暂时没有回答这个问题以防有人确实找到方法:)
这些问题讨论了这个问题,但没有像我期望的那样为这种设置提供解决方案:
小智 5
我最终也需要这个功能。
如果您正在监听“wheel”事件,则可以获得有关滚动的“delta”信息。然后您可以简单地将增量应用到您的目标 div。
document.addEventListener('DOMContentLoaded', function() {
const target = document.querySelector('#container');
// listen on the whole document; you could restrict this to an element though
document.addEventListener('wheel', function(event) {
target.scrollTop += event.deltaY;
});
});
Run Code Online (Sandbox Code Playgroud)
不过,我还没有在移动设备上测试过这一点,我怀疑它在移动设备上不起作用。