169 похожих чатов

Приветствую. Не подскажите почему не добавляется класс "header—mobile" когда расстояние

headerMenu меньше или равно 12 пикселям до правого края -

export const adaptiveHeader = () => {
const headers = document.querySelectorAll(".header");
const headerMenus = document.querySelectorAll(".header__menu");

headerMenus.forEach((headerMenu) => {
headers.forEach((header) => {
const observer = new MutationObserver(() => {
const headerMenuDistanceLeft = headerMenu.offsetLeft;
const headerMenuWidth = headerMenu.offsetWidth;
const headerWidth = header.offsetWidth;

if (headerMenuDistanceLeft + headerMenuWidth + 12 >= headerWidth) {
header.classList.add("header--mobile");
} else {
header.classList.remove("header--mobile");
};
});

observer.observe(headerMenu, { attributes: true });
});
});
}

?

12 ответов

25 просмотров

потому что это обсервер изменений, а тебе надо обсервер ресайза

ㅤ- Автор вопроса
Roman Sagiev
потому что это обсервер изменений, а тебе надо обс...

Класс "header--mobile" добавился когда расстояние между "headerMenu" меньше или равно 12 пикселям, но не убрался когда оно стало больше 12 пикселей - export const adaptiveHeader = () => { const headers = document.querySelectorAll(".header"); const headerMenus = document.querySelectorAll(".header__menu"); headerMenus.forEach((headerMenu) => { headers.forEach((header) => { const observer = new ResizeObserver(() => { const headerMenuDistanceLeft = headerMenu.offsetLeft; const headerMenuWidth = headerMenu.offsetWidth; const headerWidth = header.offsetWidth; if (headerMenuDistanceLeft + headerMenuWidth + 12 >= headerWidth) { header.classList.add("header--mobile"); } else { header.classList.remove("header--mobile"); }; }); observer.observe(headerMenu); }); }); };

ㅤ- Автор вопроса

Я её не увидел. Не могли бы вы отправить её ещё раз?


Класс "header--mobile" добавился когда расстояние ...

а еще и обсервер написан неправильно

ㅤ- Автор вопроса
Alex
Увидели?

jsfiddle не грузит почему-то


jsfiddle не грузит почему-то

https://jsbin.com/yuhororimi/edit?html,css,js,output

ㅤ- Автор вопроса
ㅤ- Автор вопроса

Работает, но с багами

У вас проблема с сеткой. Почему контент вылазит за края экрана, причем в обе стороны? Такого не должно быть, по этому и код не может нормально отработать, так как расчеты скачут. - https://i.imgur.com/meaAvNp.png

ㅤ- Автор вопроса

Как исправить проблему?)

Я не знаю. Смотрите, как Вы расположили элементы. Скорее всего они имеют фиксированную ширину.

Похожие вопросы

Обсуждают сегодня

Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
2
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
у меня программа тысяч на 10 строк. Там в основном моя собственная логика. А по содержанию она просто работает с файловой системой (мастер для бэкапов) и таблицей с данными о ...
Дмитрий Завгородний
5
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Карта сайта