С Новым годом! Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/25: Рейтинг темы: голосов - 25, средняя оценка - 4.72
5 / 5 / 0
Регистрация: 11.02.2010
Сообщений: 72

Остановка блока при прокрутке страницы вверх (подскажите)

30.07.2012, 18:09. Показов 4748. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть, например, код:
HTML5
1
2
<div class="header" style="height: 100px;"></div>
<div id="fix"></div>
Как сделать, чтоб блок "fix" при прокручивании страницы вверх оставался вверку окна браузера?
Другими словами. Если координата "top" элемента <div id="fix"> становится "0", - присвоить ему стиль position: fixed; (или класс).

P.S. Я плохо знаю синтаксис JavaScript (вернее не знаю). Но здается мне, тут надо плясать от координат окна браузера. Вот откопал скрипт, который их определяет:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
function getElementPosition(elemId)
{
   var elem = document.getElementById(elemId);
 
   var w = elem.offsetWidth;
   var h = elem.offsetHeight;
 
   var l = 0;
   var t = 0;
 
   while (elem)
   {
     l += elem.offsetLeft;
     t += elem.offsetTop;
     elem = elem.offsetParent;
   }
 
   return {"left":l, "top":t, "width": w, "height":h};
}
Т.е. сделать условие if(){}, где при условии, что "top" == 0, элементу "div" назначается class. Но как его написать, - не знаю. Вобщем, помощь нужна.
Спасибо откликнувшимся заранее!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.07.2012, 18:09
Ответы с готовыми решениями:

Исчезновение и появление блока при прокрутке страницы
Помогите сделать так, чтобы при прокрутки страницы вниз блок div сразу же исчезал, а появлялся, когда прокрутишь обратно до самого верха.

Появление div при прокрутке страницы вверх
Привет. Собственно есть сайт http://worldoftanks.ru, там при прокрутке страницы вверх, вылезает главное меню, а при прокрутке вниз...

Всплывающее окно при прокрутке уходит вверх
Как сделать, чтобы и фон затемнения и всплывающее окно оставались на месте при прокрутке? &lt;html&gt; ...

3
Эксперт JSЭксперт HTML/CSS
2436 / 1115 / 312
Регистрация: 23.06.2011
Сообщений: 3,529
31.07.2012, 09:52
Только это не валидно, хотя и работает в ИЕ, опере, лисе, хроме и сафари.


HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html><head>
<title>w123</title>
<meta http-equiv="Content-Type" content="text/html; charset=Windows-1251">
<link rel="stylesheet" type="text/css" href="scrol_2.css">
<script type="text/javascript" src="scrol_2.js"></script>
</head>
 
<body onscroll="f1();">
 
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
<div id="mnb" style="position:fixed; top:77px; font-size:222%; color:red;">0</div>
<div class="header" style="height: 100px;">qqqqqqqqqqqqqqqq</div>
<div id="fix">Поднимусь на верх и остановлюсь.</div>
 
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
text 1
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
text 2
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
text 3
<br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
text 4
 
</body>
</html>
CSS
1
2
#fix {color:hotpink;}
.fixYes {position:fixed; top:0;}
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
var f1;
(function(){
var d, scr, obj;
d=document;
 
onload=function(){
obj=d.getElementById("fix");
scr=obj.offsetTop;
 
 };
 
f1=function(){
if(d.documentElement.scrollTop||d.body.scrollTop>scr){
obj.className="fixYes";}
else{obj.className="";};
 
 
d.getElementById("mnb").innerHTML=scr+' '+s;
 
 };
 
 
 })();
0
5 / 5 / 0
Регистрация: 11.02.2010
Сообщений: 72
31.07.2012, 11:20  [ТС]
newJS, в некоторых версиях браузеров блок при прокрутке сразу скачет вверх.
Мне на jQuery подсказали решение:
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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=windows-1251" />
<title>Остановка блока при прокрутке страницы вверх</title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.0/jquery.min.js"></script>
<script language="javascript" type="text/javascript" src="script.js"></script>
<script language="JavaScript" type="text/javascript">
var TimScroll;
var Ready = true;
 
$(window).scroll(function(){
    if(Ready){
        Ready = false; clearTimeout(TimScroll);
        Scroll_Tst()
        TimScroll=setTimeout("Ready = true",10);
    } 
});
</script>
<link href="css.css" rel="stylesheet" type="text/css" />
</head>
 
<body>
 
<div class="header"></div>
 
<div id="box" class="content">
    <h1 class="title">Поднимусь на верх и остановлюсь.</h1>
    <p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /></p>
</div>
 
</body>
</html>
CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
body {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 13px;
    margin: 0;
    padding: 0px;
}
h1 {
    margin: 0;
    padding: 0px;
}
.header {
    height: 100px;
    background-color: #FCF;
}
.content {
    position:relative;
    width:100%;
    margin:0px auto;
}
.ttabl {
    width: 100%;
    text-align: left;
    /*border-bottom:1px solid black*/
}
 
.title {
    height: 30px;
    width:100%;
    position:static;
    background-color: #39F;
}
.top-visible .title {
    top:0px;
    position:fixed!important;
    width:100%;
}
.top-visible-fix {
    display:inline;
    vertical-align:bottom;
 
}
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
function Scroll_Tst(){
  var WinTop = $(window).scrollTop();
  var WinBottom = WinTop+$(window).height();
 
    $(".content").each(function (j) {
    var a=$(this);
    var Top = a.position().top;
    var Bottom = Top+a.height();
 
    var b = a.find("div.title");
    var b_Heig = b.outerHeight() + 30; //30 - отступ от низа
 
    if(Top > WinTop||Bottom < WinTop||Top > WinBottom) {    // container либо вне поля видимости, либо не
    $(this).attr('class','content'); return true;}  //влотную к верху экрана;
 
    if(Bottom > WinTop && Top < WinTop ){   //container влотную к верху экрана;
    if(Bottom - b_Heig > WinTop){$(this).attr('class','content top-visible');
    } else {$(this).attr('class','content top-visible-fix')}
    return true;}
 
    });
}
Правда, ради этого библиотеку подключать надо.
0
Эксперт JSЭксперт HTML/CSS
2436 / 1115 / 312
Регистрация: 23.06.2011
Сообщений: 3,529
31.07.2012, 20:52
Цитата Сообщение от olf Посмотреть сообщение
в некоторых версиях браузеров блок при прокрутке сразу скачет вверх.
Извини, это я виноват, неудачно подредактировал, скобки пропустил.
здесь ошибка
JavaScript
1
if(d.documentElement.scrollTop||d.body.scrollTop>scr){
так правильно
JavaScript
1
if((d.documentElement.scrollTop||d.body.scrollTop)>scr){
эту строку удалить
JavaScript
1
d.getElementById("mnb").innerHTML=scr+' '+s;
и эту в html
HTML5
1
<div id="mnb" style="position:fixed; top:77px; font-size:222%; color:red;">0</div>


новая версия
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
(function(){
var d, scr, obj;
d=document;
 
onload=function(){
if(d.addEventListener){d.addEventListener('scroll', f1, false);}
else{d.body.onscroll=f1;};//осёл
obj=d.getElementById("fix");
scr=obj.offsetTop;
 };
 
function f1(){
 
if((d.documentElement.scrollTop||d.body.scrollTop)>scr){obj.className="fixYes";}
else{obj.className=null;};
//или так, если два или более классов
/*
var s;
s=obj.className;
if((d.documentElement.scrollTop||d.body.scrollTop)>scr){
if(s.indexOf("fixYes")<0){obj.className+=" fixYes";}}
else{if(s.indexOf("fixYes")>=0){obj.className=s.replace(/ fixYes/g, "");}};
*/
 
 };
 
 })();
В htmk в body удалить событие, оно теперь скриптом вешается.
css тот же.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.07.2012, 20:52
Помогаю со студенческими работами здесь

При прокрутке вниз блок убирается а если прокрутить вверх то появляется
Вот на сайте http://samsonos.com шапка так организована как сделать что б убиралась шапка если прокрутка вниз но появлялась если прокрутка...

Рывки при прокрутке блока
Всем привет! Есть div: .1{width:100%;height:100%;overflow:auto;position:absolute;} в него добавляю еще div: ...

Как сделать, чтобы при прокрутке странички вверх происходило событие изменения класса?
Подскажите как сделать, что бы при прокрутке странички вверх происходило событие изменения класса, а если снова вниз крутить оно...

Ajax подгрузка из базы при прокрутке блока
Прошу дать пример либо объяснить как реализовать подгрузку информации в блок, когда его скрол будет внизу. Видел примеры для страницы в...

Изменение цвета fixed-блока при прокрутке сайта
Собственно есть сайт. Шапка сайта содержит прозрачное меню с белым текстом. Как сделать так чтобы при прохождении определённого...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru