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

Всем привет! Вопрос: у меня есть выпадающее меню, при клике

на toggler выполняется функция которая сворачивает/разворачивает меню (изменяет высоту выпадающего меню (от нуля до высоты содержимого)). Как мне более правильно менять высоту меню? через ref.current.style.setProperty или менять состояние styles и подключить его в prop style?

5 ответов

8 просмотров
Maxim-Korotchiy Автор вопроса

короче говоря, как правильно? при изменении стиля компонента перерисовывать его или можно просто через ref поменять стиль без перерисовки?

Maxim Korotchiy
короче говоря, как правильно? при изменении стиля ...

Что значит поменять стиль без перерисовки? Посмотрите, из чего состоит цикл отрисовки в профайлере в Chrome. У вас будет фаза Layout, фаза рендеринга. Вопрос только в том, что будет делаться в Layout, насколько дорого.

Maxim-Korotchiy Автор вопроса

ну на сколько я знаю если изменить prop style через useState, то компонент перерисуется, а если через ref.current.style.setProperty, то перерисовки не будет компонента

Maxim Korotchiy
ну на сколько я знаю если изменить prop style чере...

Вы наверное имеете в виду, что не будет перерассчета стиля, и есть шанс, что не вызовется layout, если поменять только то, что не вызовет переасчет layout, а в случае присвоения нового стиля целиком, layout будет перерасчитываться. С перерасчетом Layout существенно дороже, но отрисовка все равно будет, это то, что формирует пиксели на экране, которые вы видите. Нужно смотреть, изменение каких свойств вызывает операцию layout

Maxim Korotchiy
ну на сколько я знаю если изменить prop style чере...

Вот здесь есть некоторые методы, как двигать элемент без layout reflow. https://stackoverflow.com/questions/35306531/change-width-of-element-without-reflow

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

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

Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
38
Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
65
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
24
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
А чем вам питонисты не угодили?😂
.
79
у меня вопрос на счет .global <name> для чего это нужно если я пишу на ассемблере? только для того что бы сделать это видимым для линкера? вот что написано в докумментации GA...
Simple Sorcerer
1
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
У меня вот только только был затык при изучении одной темы. Я настолько привык к джс, что мозг с трудом признал таки, что f и \x -> f x - это равные функции. Потому что в д...
xfides Barabanov
7
Карта сайта