cyberdoge / mercury-test-task-react Goto Github PK
View Code? Open in Web Editor NEWrewrite https://github.com/CyberDoge/CyberDoge.github.io to react app
rewrite https://github.com/CyberDoge/CyberDoge.github.io to react app
Из ревью ТЗ при отборе на стажировку:
Код гораздо лучше читается, когда он отформатирован в едином стиле: отступы, максимальная длина строки, тип кавычек и т.д.
На своих проектах мы используем инструмент Prettier https://prettier.io/
Попробуй применить этот инструмент в своей работе со стандартной конфигурацией.
Код стоит выделять в компонент не только по признаку того, что он делает (форма авторизации и профиль профиль пользователя). Компонент это "строительный материал" интерфейсов, позволяющий "собирать" экраны приложений в едином стиле.
Иногда набор таких компонентов называют UI Kit. По сути это такой HTML++, который из коробки красивый.
Например, такой код легко читается, но выглядит плохо.
Стандартный внешний вид html элементов очень далек от того, что мы привыкли видеть в веб приложениях
<form>
<input type="email" placeholder="E-mail" />
<input type="password" placeholder="Password" />
<button>Login<button>
</form>
React позволяет нам сделать собственный набор элементов, который не будет уступать в читаемости, но исправит внешний вид:
<Form>
<Input type="email" placeholder="E-mail" />
<Input type="password" placeholder="Password" />
<Button>Login<Button>
</Form>
Компоненты Form, Input и Button — это как раз компоненты, которые можно объединить в UI Kit. С помощью этих же компонентов можно создать, например, форму регистрации и она будет выглядеть в том же стиле.
При создании различных админок для проектов мы часто используем Material UI. Выбирая названия свойств для собственных компонентов или для собственного UI Kit можно ориентироваться на API компонентов Material UI.
Преимущества компонентного подхода в том, что мы можем рассматривать компонент как отдельный самодостаточный элемент интерфейса. Чтобы этого достичь, стили компонента должны быть обособлены друг от друга. Т.е. стили компонента А должны использоваться явно только внутри компонента А.
В этом хорошо помогает БЭМ. Блок из БЭМа = компоненту в React. Стили компонента следует держать в CSS файле в одной папке с самим компонентом. При это внутри этого CSS файла должны быть только классы, которые относятся к текущему блоку;
Из документации БЭМ:
Название блока характеризует смысл («что это?» — «меню»: menu, «кнопка»: button), а не состояние («какой, как выглядит?» — «красный»: red, «большой»: big).
Можно заменить слово "блок" на "компонент" и пользоваться этим правилом. В твоей работе меня смущает название CentralBlock
A declarative, efficient, and flexible JavaScript library for building user interfaces.
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google ❤️ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.