Javascript-форум (https://javascript.ru/forum/)
-   jQuery (https://javascript.ru/forum/jquery/)
-   -   scrollTop - проблема chrome/safari (https://javascript.ru/forum/jquery/24873-scrolltop-problema-chrome-safari.html)

Skyman 17.01.2012 18:17

scrollTop - проблема chrome/safari
 
Необходимо вычислить верхний отступ от видимой части окна.
Со всеми браузерами все ок, но в хроме и сафари выдает 0.

var main_margin;
main_margin = $("html,body").scrollTop();
alert(main_margin);


Пробовал вместо html,body писать только body, но ничего не выходит.

Nekromancer 17.01.2012 18:59

$(document).scrollTop()

Skyman 17.01.2012 22:30

Nekromancer, тоже самое, WebKit выдает 0.

Nekromancer 17.01.2012 23:08

Nekromancer,
доктайп поставьте то. Всё должно работать вообще то и работает у всех.

Skyman 17.01.2012 23:24

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
	var margin_top;
	margin_top = $(document).scrollTop();
	alert(margin_top);
});
</script>
</head>
<body>
<div style="height: 2500px;"></div>
</body>
</html>

Прокручиваю страницу до конца, нажимаю F5 - получаю 0.
Что я делаю не так? :)

Nekromancer 17.01.2012 23:45

Skyman,
А что по вашему делает F5 - перезагружает страницу. После перезагрузки страница видимо в вебкит не прокручивается обратно.

zebra 17.01.2012 23:48

А что вы ожидали получить?

Skyman 18.01.2012 00:07

Nekromancer,
Страница перезагружается и скроллер остается в том месте, где и был (т.е. внизу).

zebra,
Необходимо получить расстояние в пикселях, между началом документа и началом видимой области окна.
Код из моего предыдущего комментария нормально работает на других браузерных движках, кроме WebKit, вот и прошу помочь.

В прокрученном до конца страницы, Firefox выдает 1595, Opera - 1561, а WebKit - 0.

zebra 18.01.2012 00:14

setTimeout пробовали?

Skyman 18.01.2012 00:19

zebra,
даже с задержкой выдает 0 :(

zebra 18.01.2012 00:21

в каком именно браузере? у меня в фф, хром, ие, опера всё норм

Skyman 18.01.2012 00:28

Chrome 16.0.912.75
Safari 5.1.2 (7534.52.7)

zebra 18.01.2012 00:33

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
	setTimeout(function() {
		var margin_top;
		margin_top = $(document).scrollTop();
		alert(margin_top);
	}, 1000);
});
</script>
</head>
<body>
<div style="height: 2500px;"></div>
</body>
</html>


Всё работает :write:

Skyman 18.01.2012 00:39

Подтверждаю, ваш код работает :)

А вот свой вариант не работает, хотя грешу на русские символы, скорее всего из-за этого, но все равно спасибо)


Часовой пояс GMT +3, время: 15:03.