4

我正在尝试在 chrome 中发送一个轮子事件,但仍然无法成功。我正在使用 WheelEvent 对象,但似乎无法正确“初始化”它。无论我做什么,delta 始终为 0。我查看了规范,但没有任何帮助。更有趣的是,当我实际使用鼠标滚轮滚动并尝试调度该事件时,我捕获了该事件,但增量再次为 0。有人遇到过这样的问题吗?这可能是一个错误吗?任何帮助都会很棒!

//dispatching the wheel event
var evt = document.createEvent("WheelEvent");
evt.initEvent("mousewheel", true, true, null, 0, 0, 0, 0, 0, false, false, false, false, 0, null, -120);
window.dispatchEvent(evt)

// catching the wheel event
window.addEventListener('mousewheel', callback, true);
callback = function(evt){
       console.log(evt)
}
4

1 回答 1

2

起初我不再需要这个功能,但我最近回到了这个问题,并找到了一种在 Chrome 上正确调度 wheel 事件的方法。抱歉耽搁了,我完全忘记了这个问题。代码如下:

var evt = document.createEvent("WheelEvent");
evt.initWebKitWheelEvent(deltaX, deltaY, window, screenX, screenY, clientX,
                        clientY, ctrlKey, altKey, shiftKey, metaKey);
node.dispatchEvent(evt);

更多信息可以在这里找到。希望这可以帮助。

于 2012-10-19T20:13:02.533 回答