Существует ошибка или несовместимость внутри эффекта наложения jQuery. Трудно найти, потому что поведение Opera имеет больше смысла, но не соответствует ожиданиям сценария.
Сначала сравните вывод этой команды в Opera и, например, Firefox:
javascript:alert(getComputedStyle(document.getElementById("cuisineListLink"),'').top);
Opera дает вам верхнюю позицию kitchenListLink в пикселях. Firefox говорит «авто».
Теперь, в сочетании с .js ищите этот код (завернутый мной):
if(typeof t=="string"){
t=t=="center"?Math.max((n.height()-q)/2,0):parseInt(t,10)/100*n.height()
}
Я понятия не имею, почему он выполняет «parseInt (t, 10) /100*n.height ()», но похоже, что этот код ожидает либо строку «центр» (для вертикального центрирования слоя), либо число. Когда Opera передает строку типа «310px», скрипт извлекает целое число, делит его на 100 (т. Е. 3.1) и умножает на высоту окна браузера (?!). Чистый эффект заключается в том, что наложение аккуратно расположено за пределами экрана - на 3 высоты экрана вниз.
В Firefox мы попадаем на эту строку, а переменная t - это строка 'auto'. Скрипт пытается выполнить parseInt (), который возвращает «Not a Number», NaN, и переходит к делению на 100 и умножению на высоту окна - что, конечно, продолжает возвращать NaN. Затем он размещает оверлей на NaNpx, который браузер просто игнорирует как поддельное значение. Вы найдете предупреждение об этом в консоли ошибок Firefox.
Я бы рекомендовал использовать другой оверлейный плагин (или, возможно, более новую итерацию?), Потому что этот код не имеет особого смысла.