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

Коллеги, подскажите, пожалуйста, по следующему вопросу (делаю курс с Udemy): 1.

Лектор создал UI компонент для Button - https://i.imgur.com/IEVsVyX.png.
2. Он использовал его в другом компоненте - https://i.imgur.com/BtcQLd6.png.
3. Я понял, как это работает, но мне кажется, что это "какие-то не очень полезные дополнительные действия". Не проще ли было бы создать единый css файл, загрузить туда класс .button и просто присваивать его для кнопок? Это философский вопрос, просто вот не очень понимаю смысл.

8 ответов

10 просмотров

Если бы ты делал это только через класс, то не смог бы переиспользовать функционал кнопки. Это и есть компонентный подход, то есть делить на компоненты и переиспользовать их в случае чего.

Andrew-Summers Автор вопроса

ну да, то есть, в Button компоненте может быть прописана бизнес-логика, которую не удается передать через css классы и поэтому мы используем компоненты, правильно понял?

Здесь дело не в классе, а в самом компоненте. Лектор вам пытался показать, минимальный модульный подход. К сожалению в данном примере он не добавил дополнительный функционал в этот компонент и для вас это выглядит, как обычная кнопка, которую вынесли в отдельный файл, но представьте, что эта кнопка будет по нажатию подгружать новые статьи или отправлять данные, для этого ее и выносят в отдельный файл, чтобы потом не дублировать эту логику.

Плюсую

Andrew-Summers Автор вопроса

понял, компонент включает как стили. так и логику. Можно переиспользовать такие компоненты, а не писать JS заново. Спасибо, разобрался.

Так же есть понятие модульных стилей. По факту те же стили, но их можно использовать как переменные. Их преимущество в том, что реакт на выходе вместо класса .button, напишет .button_h3gvd, где h3gvd является хэшем. Что даёт возможность делать одинаковые по названию классы, но разные по наполнению. И благодаря хэшу они в одном и том же компоненте не будут пересекаться.

На здоровье

Andrew-Summers Автор вопроса

да, эта тема будет раскрута на следующих уроках, спасибо за наводку

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта