【问题标题】:Disable scrolling but still raise the event in Javascript禁用滚动但仍然在 Javascript 中引发事件
【发布时间】:2012-10-09 12:09:32
【问题描述】:

在你说什么之前,我意识到已经有非常相似的问题,但它们并没有给出我所需要的。

我的问题是如何在 Javascript 中阻止用户滚动,但我仍然可以通过类似的方式引发事件。

window.onload = function()
{
    //adding the event listerner for Mozilla
    if(window.addEventListener)
        document.addEventListener('DOMMouseScroll', moveObject, false);

    //for IE/OPERA etc
    document.onmousewheel = moveObject;
}
function moveObject(event)
{
    //CODE
}

编辑: 然后我需要让用户再次滚动。

【问题讨论】:

  • 所以你的意思是物理上阻止页面滚动?
  • 是的,如果我理解你,这就是我想要的。
  • 要重新启用滚动,您可以使用document.removeEventListener。或者您可以让您的处理程序检查您更新的全局变量或 DOM 元素,以指示是否应允许滚动。

标签: javascript dom scroll dom-events


【解决方案1】:

您需要从您的事件处理程序中return false;

function moveObject(event)
{
    //CODE
    return false;
}

【讨论】:

  • 你确定不是event.preventDefault()
  • 现在它工作得很好,我只需要一种重新启动它的方法,但我可以很容易地弄清楚谢谢。和@ianpgall 将停止引发事件。
  • @ianpgall 从事件处理程序返回 false 等效于调用 event.preventDefault()event.stopPropagation
  • @Barmar 你确定吗?我认为这是一个只有 jQuery 才能做到的事情。如果我错了也没关系,我只是认为如果不使用 jQuery,你需要分别调用每个
  • @ianpgall 返回 false 是阻止默认操作的原始方法。函数稍后出现,但保留返回以保持兼容性
猜你喜欢
  • 1970-01-01
  • 2021-10-29
  • 2013-05-16
  • 1970-01-01
  • 2021-12-12
  • 2013-08-03
  • 2018-07-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多