1 / 1 / 0
Регистрация: 19.08.2013
Сообщений: 163

Как обратиться к блоку, который в поле видимости?

18.10.2019, 22:02. Показов 2106. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Хочу реализовать появление блоков при прокрутке через GSAP. Подскажите, как можно обратиться к блокам, которые находится в поле видимости?
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
<div class="box"></div>
JavaScript
1
2
3
4
5
6
7
8
// find elements
var banner = $("#banner-message")
var button = $("button")
 
// handle click and add class
button.on("click", function(){
  banner.addClass("alt")
})
CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}
 
.box    {
    width: 150px;
    height: 150px;
    margin: 50px;
    background: white;
    float:left;
}
https://jsfiddle.net/drkrol/yvduhk28/5/
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.10.2019, 22:02
Ответы с готовыми решениями:

Как обратиться к блоку, не используя ById и ClassName
Привет, нужно убрать id с кнопок, та и не только с кнопок, но я к ним таким образом обращался, можно ли как-то обратиться к...

Как обратиться к первому по парядку блоку div?
У меня есть код, примерно следующего типа &lt;div id=&quot;block&quot;&gt; &lt;div class=&quot;myclass&quot;&gt;&lt;/div&gt; &lt;div...

Как применить стиль к элементу/блоку на который кликнули?
Как применить стиль к элементу/блоку на который кликнули?

7
 Аватар для Yura007
61 / 44 / 16
Регистрация: 09.02.2019
Сообщений: 149
18.10.2019, 23:25
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// ...содержимое страницы выше...
 
function isVisible(elem) {
 
  let coords = elem.getBoundingClientRect();
 
  let windowHeight = document.documentElement.clientHeight;
 
  // верхний край элемента виден?
  let topVisible = coords.top > 0 && coords.top < windowHeight;
 
  // нижний край элемента виден?
  let bottomVisible = coords.bottom < windowHeight && coords.bottom > 0;
 
  return topVisible || bottomVisible;
}

JavaScript
1
2
3
4
5
6
7
8
9
function showVisible() {
  for (let obj of document.querySelectorAll('класс объекта за которым будем наблюдать')) {
   
 
    if (isVisible(элемент который хотите проверить находится ли он в зоне видимости)) {
    действия над элементом  
    }
  }
}
showVisible();
window.onscroll = showVisible;
0
1 / 1 / 0
Регистрация: 19.08.2013
Сообщений: 163
19.10.2019, 14:34  [ТС]
А класс объекта за которым будем наблюдать и элемент который хотите проверить находится ли он в зоне видимости должны быть разными?

Вот я попытался встроить ваш код в мой
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
function isVisible(elem) {
 
  let coords = elem.getBoundingClientRect();
 
  let windowHeight = document.documentElement.clientHeight;
 
  // верхний край элемента виден?
  let topVisible = coords.top > 0 && coords.top < windowHeight;
 
  // нижний край элемента виден?
  let bottomVisible = coords.bottom < windowHeight && coords.bottom > 0;
 
  return topVisible || bottomVisible;
}
 
function showVisible() {
  for (let obj of document.querySelectorAll('.box')) {
   
 
    if (isVisible($('.box'))) {
    console.log(this)
    }
  }
}
 
 
$(window).bind('wheel', function(event) {
    // ------- ВНИЗ
    if (event.originalEvent.deltaY >= 0) {
                  console.log("вниз");  
function showVisible() {
  for (let obj of document.querySelectorAll('.box')) {
    if (isVisible($('.box'))) {
    console.log(this);
    }
  }
}
    // ----ВВЕРХ
    } else {
                console.log("вверх");
       
        }
 
});
jssfiddle: https://jsfiddle.net/drkrol/yvduhk28/8/
По логике я должен во время прокрутки, если объекты в зоне видимости, получить их свойства в console.log
0
 Аватар для Yura007
61 / 44 / 16
Регистрация: 09.02.2019
Сообщений: 149
19.10.2019, 21:04
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
34
35
36
<div class="IseeYou" >1 </div>
<div class="IseeYou" > 2</div>
<div class="IseeYou" > 3</div>
<div class="IseeYou" > 4</div>
<div class="IseeYou" > 5</div>
<div class="IseeYou" > 6</div>
<div class="IseeYou" >7 </div>
<div class="IseeYou" >8</div>
<div class="IseeYou" > 9</div>
<div class="IseeYou" >10 </div>
<div class="IseeYou" > 11</div>
<div class="IseeYou" > 12</div>
<div class="IseeYou" > 13</div>
<div class="IseeYou" > 14</div>
<div class="IseeYou" > 15</div>
<div class="IseeYou" >16 </div>
<div class="IseeYou" >17 </div>
<div class="IseeYou" > 18</div>
<div class="IseeYou" >19 </div>
<div class="IseeYou" > 20</div>
<div class="IseeYou" > 21</div>
<div class="IseeYou" > 22</div>
<div class="IseeYou" > 23</div>
<div class="IseeYou" > 24</div>
<div class="IseeYou" >25 </div>
<div class="IseeYou" >26</div>
<div class="IseeYou" > 27</div>
<div class="IseeYou" >28 </div>
<div class="IseeYou" > 29</div>
<div class="IseeYou" > 30</div>
<div class="IseeYou" > 31</div>
<div class="IseeYou" > 32</div>
<div class="IseeYou" > 33</div>
<div class="IseeYou" >34 </div>
<div class="IseeYou" >35 </div>
<div class="IseeYou" > 36</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
28
29
30
31
function isVisible(elem) {
 
  let coords = elem.getBoundingClientRect();
 
  let windowHeight = document.body.clientHeight;
 
  // верхний край элемента виден?
  
  let topVisible = coords.top > 0 && coords.top < windowHeight;
 
  // нижний край элемента виден?
  let bottomVisible = coords.bottom < windowHeight && coords.bottom > 0;
 
  return topVisible || bottomVisible;
}
 
function showVisible() {
  for (let obj of document.querySelectorAll('.IseeYou')) {   
  
    if (isVisible(obj)) {
    console.log("Смотри на меня ")
    console.log(obj)
 
    }
  }
}
showVisible();
 
 
 
window.onscroll = showVisible;
Добавлено через 1 минуту
вставите в html и при прокрутке в консоле будет отзыв от тех блоков которые попадают в видимую область

Добавлено через 33 минуты
CSS
1
2
3
4
5
6
7
8
.IseeYou {
  height: 100px;
  width: 100px
    ;
  background: #4ca75f;
  display: block;
  margin-bottom: 10px;
}
0
Эксперт JS
2037 / 1096 / 409
Регистрация: 29.04.2016
Сообщений: 2,625
20.10.2019, 02:34
drkrol,

https://codepen.io/Mr_Sergo/pen/oNNYGEg

JavaScript
1
2
3
4
5
6
7
const observer = new IntersectionObserver((entries, observer) => {
    entries.forEach(n => n.target.classList.toggle('red', n.isIntersecting));
}, {
    threshold: 0.5
});
 
document.querySelectorAll('.box').forEach(n => observer.observe(n));
0
1 / 1 / 0
Регистрация: 19.08.2013
Сообщений: 163
21.10.2019, 22:38  [ТС]
Yura007, очень круто, понятно, но не работает:

я должен видеть в консоли: 35 - 36, но их нет...
Mr_Sergo, непонятно... Вы дали готовое решение, которое я не смог разобрать. Мне же в идеале нужно obj получить, а потом с ним работать
0
Эксперт JS
2037 / 1096 / 409
Регистрация: 29.04.2016
Сообщений: 2,625
22.10.2019, 06:00
Что значит
Цитата Сообщение от drkrol Посмотреть сообщение
obj получить
?

Если вам нужно
Цитата Сообщение от drkrol Посмотреть сообщение
обратиться к блокам, которые находится в поле видимости
то так
JavaScript
1
2
3
4
5
6
7
8
9
const Observer = new IntersectionObserver((entries, imgObserver) => {
    entries.forEach(e => e.isIntersecting && onVisible(e.target) )
},{ threshold: 0.5 });  // 0.5 - это число на которое элемент должен появиться в поле видимости (50%), если, к примеру, нужно обратиться к элементу только тогда когда он целиком виден то поменять 0.5 на 1 (100%)
 
document.querySelectorAll('.box').forEach(e => Observer.observe(e) );  // тут указываем свой клас за которым будем наблюдать
 
const onVisible = elm => {  // что делать с элементами которые в поле видимости
    console.log(elm);  // выводим их в консоль
}
0
 Аватар для Yura007
61 / 44 / 16
Регистрация: 09.02.2019
Сообщений: 149
22.10.2019, 19:01
все там работает ну бывают погрешности сделайте поправки ... это же не с нуля писать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.10.2019, 19:01
Помогаю со студенческими работами здесь

Добавление класса блоку при его появление в области видимости окна браузера
Доброго времени суток При прокрутке страницы необходимо добавить блоку с class=&quot;block_scroll&quot; класс anim Если блок на...

Как обратиться к объекту в который бьет луч?
Как обратиться к объекту в который бьет луч? То есть, есть такая запись: private RaycastHit RCH; void Update{ if...

Как обратиться к массиву, который в массиве? React
Всем привет, подскажите как можно обратиться к массиву, который в массиве? Вот мой код: import React, { Component } from 'react'; ...

Как из Page обратиться к методу, который находится в MainFrame
Добрый день уважаемые программисты! Мне нужна ваша помощь. Приложение пишу в WPF. В главном окне MainWindow.xaml создал контролл...

Как обратиться к параметрам объекта, который выше по иерархии?
ДОБРЫЙ ДЕНЬ! Есть вопрос. Например, есть класс &quot;Tпомещение&quot; и есть класс &quot;Tмебель&quot;. Объект типа &quot;мебель&quot; является...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru