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

Доброго времени суток! Подскажите пожалуйста с одним моментом. Вот есть

у меня компонент, в виде горизонтального меню с горизонтальным скроллом. Стояла задача, отображать активную ссылку по центру родительского компонента. Решил таким образом, используя 2 хука:
const urlParams = useParams();

useEffect(() => {
const menuRowActiveItem = document.querySelector('.food-menu__link.active').parentElement;
menuRowActiveItem.scrollIntoView({inline: 'center', behavior: 'smooth'})
},[urlParams])
Вопрос: насколько такое прямое обращение к DOM элементам "законно" в рамках реакта? Если решение плохое, посоветуйте пожалуйста куда думать

8 ответов

4 просмотра
Sultan-Mashukov Автор вопроса

Подскажите пожалуйтса

Sultan Mashukov
Подскажите пожалуйтса

рендерить нужно с map, там указывать в style жные стили, если active === true

Sultan Mashukov
Подскажите пожалуйтса

а так к селекторам обращаться без отсутствия других вариантов не надо

Sultan Mashukov
Подскажите пожалуйтса

нужно хранить в данные Links в массиве, это в принципе правильно, а не писать ручками одинаковые компоненты с разными children и href

Sultan-Mashukov Автор вопроса
Mihail Grushetckii
а так к селекторам обращаться без отсутствия други...

Если обратите еще раз внимание, там речи о стиля не идет. Я вызываю на активной ссылке метод scrollIntoView

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

Sultan-Mashukov Автор вопроса
Roman M
вероятно уже ответили, но все же напишу, что реакт...

Ну конкретно в моем случае же, я толком никаких операции с DOM не произвожу, по крайней мере с данными. Метод scrollIntoView грубо говоря "скроллит" родительский элемент до предка, на котором он был вызван.

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
еще вопрос, допустим мы создадим char массив из 10 элементов и присвоим ему через сканф 10 символов. и выведем все символы. Хотел спросить последний элемент /0 будет включать...
Anthem
10
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
открыть папку в проводнике: 1 - ShellExecute 2 - ExecuteProcess 3 - OpenDocument что лучше выбрать?
Alexey Kulakov
12
Изменение типа с SomeException на String и правда удобней @cheese_hs . А вот такой вариант насколько некрасив еще? loadConfigDB :: IO (Either String ConfigDataBase) loadConfi...
Camara
7
Где в Астане можно купить мясо для шашлыков?
Dancing Іңұқәһүғө
21
Карта сайта