Zrobiłem ten przykład tutaj: http://jsbin.com/pokahec/edit?html,outputVimeo iFrame Kradzież Wheel Mouse wydarzenie na Firefox
// creates a global "addWheelListener" method
// example: addWheelListener(elem, function(e) { console.log(e.deltaY); e.preventDefault(); });
(function(window,document) {
var prefix = "", _addEventListener, onwheel, support;
// detect event model
if (window.addEventListener) {
_addEventListener = "addEventListener";
} else {
_addEventListener = "attachEvent";
prefix = "on";
}
// detect available wheel event
support = "onwheel" in document.createElement("div") ? "wheel" : // Modern browsers support "wheel"
document.onmousewheel !== undefined ? "mousewheel" : // Webkit and IE support at least "mousewheel"
"DOMMouseScroll"; // let's assume that remaining browsers are older Firefox
window.addWheelListener = function(elem, callback, useCapture) {
_addWheelListener(elem, support, callback, useCapture);
// handle MozMousePixelScroll in older Firefox
if(support == "DOMMouseScroll") {
_addWheelListener(elem, "MozMousePixelScroll", callback, useCapture);
}
};
function _addWheelListener(elem, eventName, callback, useCapture) {
elem[ _addEventListener ](prefix + eventName, support == "wheel" ? callback : function(originalEvent) {
!originalEvent && (originalEvent = window.event);
// create a normalized event object
var event = {
// keep a ref to the original event object
originalEvent: originalEvent,
target: originalEvent.target || originalEvent.srcElement,
type: "wheel",
deltaMode: originalEvent.type == "MozMousePixelScroll" ? 0 : 1,
deltaX: 0,
deltaZ: 0,
preventDefault: function() {
originalEvent.preventDefault ?
originalEvent.preventDefault() :
originalEvent.returnValue = false;
}
};
// calculate deltaY (and deltaX) according to the event
if (support == "mousewheel") {
event.deltaY = - 1/40 * originalEvent.wheelDelta;
// Webkit also support wheelDeltaX
originalEvent.wheelDeltaX && (event.deltaX = - 1/40 * originalEvent.wheelDeltaX);
} else {
event.deltaY = originalEvent.detail;
}
// it's time to fire the callback
return callback(event);
}, useCapture || false);
}
}) (okno, dokument);
można przetestować w Firefoksie że przewinąć zdarzenie jest zwolniony, z wyjątkiem gdy na Vimeo iframe (i chyba żadnej iFrame)
Czy istnieje rozwiązanie na ogień zdarzenia na iframe?
PS - Chcę użyć tego w zwyczaju przewijania
, więc nie hack możliwe? – digitalzoomstudio
Cóż, przypuszczam, że możesz umieścić przezroczysty DIV na IFRAME - ale Twój gość prawdopodobnie utraci możliwość odtwarzania/wstrzymywania wideo. – hallvors
Ponadto, jeśli dodasz atrybut "scrolling = no" w IFRAME, przeglądarka nie będzie przewijać zawartości IFRAME osobno.Nie wiem, czy to pomoże w przypadku użycia - zewnętrzna strona będzie przewijana po uniesieniu IFRAME, ale nie otrzymasz żadnych zdarzeń, dopóki IFRAME nie będzie przeszkadzać. – hallvors