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

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

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

8 ответов

3 просмотра

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

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

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

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

Плюсую

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

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

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

На здоровье

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

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

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

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

А чем вам питонисты не угодили?😂
.
79
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Подскажите, можно ведь комбинировать запись данных в один и тот же Stream через TFileStream и через TCompressionStream поочерёдно? Ну т.е. часть данных мне нужно сжать, часть ...
notme
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ребят, кто сталкивался с тем, что Electron.js не разворачивает билд React.js-приложения? Голый body в чёрном цвете, как и должно быть, но остального - нет. Билд работает исп...
..
6
Anyone knows how to build this widget in Flutter? I have all the assets for round stations and the road, but how can I make the my widget animate between these stations? And h...
Mohammad Zamani
9
Карта сайта