Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про JavaScript: intersectionobserver

Как можно заменить position: sticky, если бы его не было?

Вопрос проверяет понимание альтернативных способов создания свойств в CSS

Короткий ответ

Можно использовать position: fixed + JavaScript для динамического вычисления позиции элемента при скролле. Также можно применить IntersectionObserver для отслеживания положения элемента и переключения его стилей.

Длинный ответ

  1. Использование position: fixed + JavaScript

Если sticky недоступен, можно имитировать его поведение:

  • При скролле страницы вычислять, когда элемент должен "прилипнуть".

  • Переключать position: relative → position: fixed при достижении границы.

Пример:

const stickyElement = document.querySelector('.sticky');
const offset = stickyElement.offsetTop;
window.addEventListener('scroll', () => {
	if (window.scrollY >= offset) {
		stickyElement.style.position = 'fixed';
		stickyElement.style.top = '0';
	} else {
		stickyElement.style.position = 'relative';
	}
});
  1. Использование IntersectionObserver

Более современный способ — отслеживать, когда элемент достигает границы:

const observer = new IntersectionObserver(
  	(entries) => {
    		entries.forEach((entry) => {
      			if (entry.isIntersecting) {
        			entry.target.style.position = 'fixed';
        			entry.target.style.top = '0';
      			} else {
        			entry.target.style.position = 'relative';
      			}
    		});
  	},
  	{ threshold: 1 }
);

observer.observe(document.querySelector('.sticky'));
  1. Альтернатива с transform: translateY

Если нужно плавное поведение, можно анимировать положение элемента:

.sticky {
	position: relative;
	transition: transform 0.2s;
}
.sticky.fixed {
	transform: translateY(var(--scroll-offset));
}
window.addEventListener('scroll', () => {
	const scrollY = window.scrollY;
	stickyElement.classList.toggle('fixed', scrollY > offset);
});

Уровень

  • Рейтинг:

    3

  • Сложность:

    8

Навыки

  • JavaScript

    JavaScript

  • CSS

    CSS

Ключевые слова

#intersectionobserver

Подпишись на React Developer в телеграм