Всякий раз, когда я изменяю zIndex данного div (даже на то же значение), его свойство scrollTop сбрасывается, и оно прокручивается обратно к началу.Это вызывает очень неприятный эффект для моего сайта (замедление и черный прямоугольник по всему div, пока он перерисовывается).После сброса scrollTop я могу установить его обратно, но это вызывает еще один ужасный перекрас.
Эта ошибка FF сводит меня с ума!Я отправил сообщение об ошибке в Mozilla https://bugzilla.mozilla.org/show_bug.cgi?id=623937, но им все равно над этим работать!Пожалуйста, если кто-нибудь знает, как обойти эту проблему с помощью магии JavaScript?Может, поиграть с прототипом HTMLElement, чтобы как-то переопределить scrollTop?
Вот небольшой тестовый пример "
<html>
<head>
<style type="text/css">
div#parentDiv
{
position: absolute;
top: 10px;
left: 10px;
width: 300px;
height: 200px;
background-color: green;
}
div#elementToScroll
{
position: absolute;
top: 40px;
left: 40px;
width: 200px;
height: 100px;
overflow-y: hidden;
background-color: blue;
color: white;
}
</style>
</head>
<body>
<div id="parentDiv">
This is the parent DIV
<div id="elementToScroll">This is the child div with overflow-y: hidden and content a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of a lot of ; </div>
</div>
<script>
var parentDIV = document.getElementById("parentDiv");
var elementToScroll = document.getElementById("elementToScroll");
alert ("elementToScroll.scrollTop initial: " + elementToScroll.scrollTop);
elementToScroll.scrollTop = 20;
alert ("We set elementToScroll.scrollTop = 20: current value is: " + elementToScroll.scrollTop);
parentDIV.style.zIndex = 0;
alert ("We set parentDIV.style.zIndex and now elementToScroll.scrollTop is: " + elementToScroll.scrollTop);
</script>
</body>
</html>