Ho fatto questo esempio qui: http://jsbin.com/pokahec/edit?html,outputVimeo iFrame Rubare rotellina del mouse Event su 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);
}
}) (finestra, documento);
È possibile verificare in Firefox che scorrere evento viene generato, ad eccezione di quando sopra vimeo iframe (e credo che qualsiasi iFrame)
C'è qualche soluzione al fuoco evento su iframe?
PS - Voglio utilizzare questo in una barra di scorrimento personalizzato
quindi non è possibile l'hacking? – digitalzoomstudio
Beh, suppongo che potresti mettere un DIV trasparente sopra l'IFRAME - ma il tuo visitatore probabilmente perderà la possibilità di riprodurre/mettere in pausa il video. – hallvors
Inoltre, se si aggiunge un attributo "scrolling = no" all'IFRAME, il browser non scorrerà i contenuti IFRAME separatamente.Non sono sicuro se questo aiuti il tuo caso d'uso - la pagina esterna scorrerà quando l'IFRAME è al passaggio del mouse, ma non otterrai alcun evento finché l'IFRAME non è fuori strada. – hallvors