Mi rendo conto che questa è una vecchia domanda, ma penso di aver trovato una buona soluzione. Il problema è che la casella di fantasia cambia il valore di overflow del corpo per nascondere le barre di scorrimento del browser.
Come sottolinea Dave Kiss, possiamo impedire a Fancy Box di farlo aggiungendo i seguenti parametri:
$('.image').fancybox({
padding: 0,
helpers: {
overlay: {
locked: false
}
}
});
Ma ora possiamo scorrere la pagina principale mentre guardiamo la nostra finestra fantasia. È meglio che saltare all'inizio della pagina, ma probabilmente non è quello che vogliamo veramente.
Possiamo impedire lo scorrimento nel modo giusto aggiungendo i seguenti parametri:
$('.image').fancybox({
padding: 0,
helpers: {
overlay: {
locked: false
}
},
'beforeLoad': function(){
disable_scroll();
},
'afterClose': function(){
enable_scroll();
}
});
E aggiungi queste funzioni da galambalaz. Vedi: Come disabilitare temporaneamente lo scorrimento?
var keys = [37, 38, 39, 40];
function preventDefault(e) {
e = e || window.event;
if (e.preventDefault) e.preventDefault();
e.returnValue = false;
}
function keydown(e) {
for (var i = keys.length; i--;) {
if (e.keyCode === keys[i]) {
preventDefault(e);
return;
}
}
}
function wheel(e) {
preventDefault(e);
}
function disable_scroll() {
if (window.addEventListener) {
window.addEventListener('DOMMouseScroll', wheel, false);
}
window.onmousewheel = document.onmousewheel = wheel;
document.onkeydown = keydown;
}
function enable_scroll() {
if (window.removeEventListener) {
window.removeEventListener('DOMMouseScroll', wheel, false);
}
window.onmousewheel = document.onmousewheel = document.onkeydown = null;
}