Назад к вопросам
X5 tech
Middle
2
Как получить ширину DOM-элемента и отслеживать её изменения? Можно ли повесить resize на DOM-элемент через addEventListener?
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Чтобы получить ширину DOM-элемента, можно использовать свойство offsetWidth или getBoundingClientRect().width:
const element = document.getElementById('myElement');
const width = element.offsetWidth;
// или
const widthRect = element.getBoundingClientRect().width;
Для отслеживания изменений ширины элемента нельзя напрямую повесить событие resize через addEventListener, так как событие resize доступно только на объекте window.
Вместо этого используют ResizeObserver — современный API, который позволяет отслеживать изменения размеров элементов:
const resizeObserver = new ResizeObserver(entries => {
for (let entry of entries) {
console.log('Новая ширина:', entry.contentRect.width);
}
});
resizeObserver.observe(element);
Таким образом, ResizeObserver — правильный способ отслеживать изменения размеров DOM-элемента.