Ui фреймворк что это
Этот материал поможет понять, какую ценность представляют веб-фреймворки для начинающих и опытных разработчиков. Мы посмотрим, какие существуют фреймворки, какие задачи они решают и как среди них выбрать подходящие инструменты.
Примечание Вы читаете улучшенную версию некогда выпущенной нами статьи.
Веб-фреймворк — это каркас для написания веб-приложений. Он определяет структуру, задаёт правила и предоставляет необходимый набор инструментов для разработки.
Типы веб-фреймворков
Классифицировать фреймворки для веб-приложений можно по двум основаниям: задачам, которые они решают, и размеру.
Бэкенд-фреймворки
Это фреймворки веб-разработки, которые работают на серверной стороне. В основном они отвечают за отдельные, но критически важные части приложения, без которых оно не сможет нормально работать. Вот несколько самых популярных фреймворков, а также языки, с которыми они работают:
- Django — Python;
- Symfony, Laravel — PHP;
- Express.js — JavaScript;
- Ruby on Rails — Ruby.
Правила и архитектура серверных фреймворков не даёт возможности разработать веб-приложение с богатым интерфейсом. Они ограничены в своей функциональности, однако вы всё равно можете создавать простые страницы и разные формы. Также они могут формировать выходные данные и отвечать за безопасность в случае атак.
Фронтенд-фреймворки
Фронтенд-фреймворки отвечают за внешний вид веб-приложения. В отличие от серверных, они никак не связаны с логикой работы. Этот тип фреймворков работает в браузере. С их помощью можно улучшать и внедрять новые пользовательские интерфейсы, создавать разные анимации и одностраничные приложения. Вот некоторые из них:
- Angular;
- Vue.js;
- Svelte;
- React — формально это не фреймворк, а библиотека, но значение этого инструмента так велико, что его постоянно сравнивают с другими веб-фреймворками.
Все эти инструменты используют JavaScript.
Фуллстек-фреймворки
Если фреймворк решает задачи и на серверной, и на клиентской стороне, то он относится к категории фуллстек. В качестве примера можно назвать Meteor. Обе его стороны — серверная и клиентская — работают на JavaScript. Поэтому вы можете создавать и использовать для них один и тот же код. Следующая особенность — «режим реального времени». Когда вы что-то меняете в одном интерфейсе, изменения происходят и в остальных.
К фуллстек также относятся фреймворки Next.js и Nuxt. Первый создан поверх React.js, а второй работает на базе Vue.js. Такие веб-фреймворки могут быть сложными для начинающих.
Можно работать и с серверной, и с клиентской стороной веб-приложения
Фреймворки и микрофреймворки
Фреймворки веб-разработки отличаются по размеру. Существуют монструозные инструменты, которые предлагают решения для всего. Более легковесные варианты специализируются на решении конкретных задач. Такие фреймворки называются микрофреймворками. Их функциональность расширяется с помощью сторонних приложений. Вы можете создавать на их основе небольшие проекты или совместить микрофреймворк с большим фреймворком.
27–28 ноября, Москва, Беcплатно
Архитектура веб-фреймворков
Архитектура почти всех популярных веб-фреймворков основана на декомпозиции нескольких отдельных слоёв (приложения, модули и т.д.). Это означает, что вы можете расширять функциональность, исходя из своих потребностей, и использовать изменённую версию вместе с кодом фреймворка или добавлять сторонние приложения.
Существует множество open-source сообществ и коммерческих организаций, которые создают приложения или расширения для популярных фреймворков, например, Django REST Framework, ng-bootstrap и т.д.
MVC — Модель, Представление и Контроллер (Model-View-Controller) — три составляющих каждого веб-фреймворка.
Модель MVC используется во всех веб-фреймворках
- Модель содержит все данные и уровни бизнес-логики, её правила и функции.
- Представление отвечает за визуальное отображение данных.
- Контроллер преобразует входные данные в команды для Модели и Представления.
Они неотделимы друг от друга, поэтому важно как следует во всём разобраться, чтобы избежать ошибок во время работы приложения.
Особенности веб-фреймворков
Теперь давайте посмотрим на некоторые общие особенности, которые делают фреймворки для веб-приложений многофункциональными и удобными на практике.
Веб-кэширование — помогает хранить разные документы и позволяет избежать перегрузки сервера. Пользователи могут использовать его в различных системах при соблюдении нескольких условий. Он также работает на стороне сервера. Например, вы можете заметить ссылки на кэшированный контент на странице результатов поиска Google.
Скаффолдинг — веб-фреймворки могут автоматически сгенерировать типичные части приложения или даже всю структуру проекта, это важно для начинающих. Такой подход позволяет существенно увеличить скорость разработки и стандартизирует кодовую базу.
Система веб-шаблонов — набор разных методологий и программного обеспечения, реализованных для создания и развёртывания веб-страниц. Для обработки веб-шаблонов используются шаблонизаторы. Они являются инструментом фреймворка, отвечающим за веб-публикацию.
Безопасность — есть множество средств для идентификации и разрешения или отклонения доступа к различным функциям веб-фреймворка. Инструменты безопасности также помогают распознать профили, которые используют приложение, чтобы избежать кликджекинга — механизма обмана, при котором злоумышленник получает доступ к конфиденциальной информации пользователя и даже его устройствам.
Сопоставление URL — если вы хотите упростить индексацию поисковыми движками, в то же время используя привлекательное название для сайта, то эта функция фреймворков — то, что вам нужно. Также сопоставление URL может облегчить доступ к адресам ваших сайтов.
Приложения — фреймворки позволяют разрабатывать разные веб-приложения. Наиболее распространённые инструменты используются для создания блогов, форумов, универсальных веб-сайтов, систем управления контентом (CMS)
Как выбрать подходящий веб-фреймворк
Перечисленная функциональность свойственна всем фреймворкам. Но их широкий ассортимент приводит к тому, что разработчик теряется и не может выбрать конкретный инструмент. Сузить круг помогают следующие критерии:
- предпочитаемый язык;
- возможности фреймворка.
Полезно также изучить сравнение нескольких фреймворков. Например, вот сопоставление возможностей Django и Ruby on Rails.
Веб-фреймворки для начинающих не существуют. Инструменты одинаково подходят для разработчиков разного уровня. Конечно, лучше использовать фреймворки, которые проще изучить. Однако порой написанные по правилам старой школы и редко используемые, но подходящие инструменты, могут привести вас к успеху.
Как научиться пользоваться веб-фреймворками
Научиться пользоваться фреймворками можно самостоятельно. Чтобы найти руководство по веб-фреймворкам, изучите их документацию. Главный плюс официальных источников — актуальность. В таких обучающих материалах используются возможности последних версий фреймворков.
Если в документации нет простых гайдов, можно поискать их на других площадках. Например, на freeCodeCamp есть бесплатный курс по React, а на сайте Tutorialspoint — туториалы по разным языкам и технологиям.
Неплохой источник информации — YouTube. На видеохостинге выкладывают обзоры и пошаговые руководства. Просмотр таких роликов поможет выбрать подходящий фреймворк, если вы пока сомневаетесь. Не забывайте и про StackOverflow. Но туда нужно приходить уже с конкретными вопросами, которые возникли при изучении или использовании фреймворка.
JavaScript — это технология, которая лежит в основе современных быстрых веб-приложений. Существует множество инфраструктур и библиотек пользовательского интерфейса для создания сложных, быстро реагирующих приложений.
Некоторые помогут вам написать более эффективный и поддерживаемый код. Или вам нужна помощь в разработке набора согласованных, совместимых и быстрых компонентов пользовательского интерфейса. Практически в любой ситуации вы можете найти вариант, который сделает большую часть тяжелой работы за вас. Там нет необходимости начинать с нуля и изобретать велосипед.
Самые популярные доступные платформы JavaScript предоставляют некоторые общие возможности. В частности, они:
- могут сохранять состояние и просматриваться синхронизированно
- предлагают большую функциональность и маршрутизацию
- позволяют разработчикам создавать, повторно использовать и поддерживать компоненты пользовательского интерфейса, которые эффективны и быстро реагируют на взаимодействие с пользователем.
Количество доступных JS-фреймворков велико, и это число продолжает расти. Посмотрите на эти варианты. Я перечислил как стабильные, популярные библиотеки, так и новые опции для любопытных.
Давайте перейдем к изящной JavaScript-среде корпоративного уровня — Ext JS от Sencha.
Нужно создать веб-приложение, которое обрабатывает большие объемы данных, и вам нужны мощные, гибкие интерфейсные инструменты для отображения и работы с ним?
Sencha Ext JS описывается как…
наиболее полная JavaScript-инфраструктура для создания ресурсоемких, кроссплатформенных веб-приложений и мобильных приложений для любого современного устройства. Ext JS включает более 140 предварительно интегрированных и протестированных высокопроизводительных компонентов пользовательского интерфейса.
Некоторые из этих компонентов включают в себя:
- HTML5 календарь- сетки- деревья- списки- формы- меню- панели инструментови многое другое
Ext JS — это надежная, платная платформа, которая поставляется с выдающимися документами, учебными пособиями и пакетами поддержки. Недавние испытания показали, что сетка данных Ext JS была в 300 раз быстрее, чем у ведущих конкурентов. Фактически, его опыт виртуальной прокрутки извлекает и показывает большие объемы данных менее чем за секунду.
Преимущества Ext JS включают в себя:
- быстрое, плавное развитие. Наслаждайтесь плавной интеграцией между корпоративной средой и самыми современными компонентами и инструментами.
- полный набор безопасных компонентов. Вам никогда не придется выходить за рамки, чтобы найти недостающий виджет или функциональность.
- отличные возможности дизайна благодаря встроенным инструментам. Sencha Architect предлагает возможности перетаскивания. Sencha Stencils позволяет разработчикам разрабатывать, создавать прототипы и тестировать концепции пользовательского интерфейса.
- потрясающие модульные и комплексные инструменты тестирования с Sencha Test.
- менеджер по верстке. Управляйте отображением данных и контента в разных браузерах и экранах разных размеров. Адаптивная система конфигурации адаптирует интерфейс к ориентации устройства и размерам окна браузера.
- легко достичь соответствия доступности с пакетом Ext JS ARIA- надежный пакет данных, который отделяет компоненты пользовательского интерфейса от уровня данных.
React чрезвычайно популярен среди разработчиков. Это библиотека JavaScript с открытым исходным кодом для создания невероятно быстрых интерактивных интерфейсов. React был впервые создан Джорданом Уолком, инженером-программистом, работающим в Facebook. Впервые он был размещен на новостной ленте Facebook в 2011 году, а в Instagram — в 2012 году. Его используют такие компании, как Netflix, Airbnb, Instagram и New York Times, и многие другие.
Причины выбора React для реализации вашего следующего проекта:
- React быстр в освоении и использовании. Это JavaScript с небольшим API.
- Компоненты кода стабильны и могут быть использованы повторно. Их легко создавать и поддерживать с использованием декларативного синтаксиса API.
- Большие компании и сильное сообщество поддерживают React.
- Библиотека не зависит от стека, также может отображаться на сервере с помощью Node.js и в мобильных приложениях с React Native.
Можете записаться на наши курсы по React, где вы сможете ознакомиться, протестировать и создать свой проект с React.
Angular — это бесплатная платформа Google с открытым исходным кодом, которая работает как для настольных, так и для мобильных устройств.
Существует кривая обучения, в том числе знакомство с TypeScript, расширенным набором JavaScript. Несмотря на это, Angular остается отличной основой для работы. Вот некоторые из причин его использования:
- кроссплатформенность — прогрессивные веб-приложения, собственные мобильные приложения и рабочий стол
- предлагает скорость и производительность
- имеет отличные функции, такие как фильтры, двустороннее связывание данных, директивы и многое другое
- делает доступными отличные инструменты для быстрой разработки
- имеет полную поддержку Google и сильное сообщество разработчиков.
Vue JS — это бесплатная прогрессивная JavaScript-инфраструктура с открытым исходным кодом, созданная Evan You. Он использует синтаксис шаблона (например, Angular) и опирается на компонентную архитектуру (например, React).
Вот как Vue описывает себя на своей собственной странице репозитория GitHub:
Vue (произносится / vjuː /, как view) — это прогрессивная структура для создания пользовательских интерфейсов. Он спроектирован с нуля для постепенного принятия и может легко масштабироваться между библиотекой и структурой в зависимости от различных вариантов использования. Он состоит из доступной базовой библиотеки, которая фокусируется только на уровне представления, и экосистемы поддержки библиотек, которая помогает вам решать сложные задачи в больших одностраничных приложениях.
Вот некоторые из самых сильных сторон Vue:
- удобно. Если вы знаете языки Интернета (HTML, CSS и JavaScript), документы Vue
- это все, что вам нужно, чтобы начать сборку сразу.
- вы можете постепенно интегрировать его в проект. Он легко масштабируется от библиотеки до полноценного фреймворка.
- маленький и поставляется с супер-быстрым виртуальным DOM.
- за ним стоит удивительное сообщество, которое делает его стабильной основой для принятия.
- предлагает отличную документацию.
Выпущенный в декабре 2011 года Иегудой Кацем и Томом Дейлом, Эмбер является:
Фреймворк для амбициозных веб-разработчиков.
Ember.js — это продуктивная, проверенная в бою инфраструктура JavaScript для создания современных веб-приложений. Он включает в себя все необходимое для создания многофункциональных интерфейсов, которые работают на любом устройстве.
Этот JavaScript-фреймворк бесплатный, с открытым исходным кодом, и за ним стоит сильное сообщество. Вот некоторые из причин, почему Ember является успешным среди разработчиков:
- использует соглашение по подходу конфигурации, отстаиваемому Дэвидом Хайнемайером Ханссоном. Он направлен на снижение количества решений, которые должен принять разработчик (без ущерба для гибкости).
- почти все, что вам нужно для настройки вашего приложения, поставляется с Ember из коробки.
- быстро принимает новейшие веб-стандарты и функции JavaScript.
- предлагает отличные документы и ресурсы.
Несмотря на то, что Svelte 3 быстро растет, он новый в мире фреймворков. Рич Харрис выпустил Svelte в ноябре 2016 года как проект с открытым исходным кодом. Версия 3 вышла в апреле 2019 года и была полностью переработана.
Svelte работает иначе, чем большинство фреймворков, перечисленных до сих пор. В частности:
В то время как традиционные фреймворки, такие как React и Vue, выполняют основную часть своей работы в браузере, Svelte переключает эту работу на этап компиляции, который происходит при создании приложения.
Многие фреймворки используют такие методы, как виртуальный анализ DOM. Вместо этого Svelte хирургически обновляет DOM при изменении состояния вашего приложения. Компиляция кода создает заметные преимущества в производительности.
Svelte — быстрый способ для начинающих. Вы можете создавать компоненты без большого количества стандартного кода. Просто используйте HTML, CSS и JavaScript. Сайт Svelte содержит ресурсы для начинающих. К ним относятся учебник, примеры и подробный API для более опытных разработчиков Svelte. Для получения помощи и поддержки вам предлагается присоединиться к выделенному серверу Discord.
Выбор основы всегда является финансовым решением. Это включает в себя внимание к проблемам вашего конкретного проекта. Это также означает учет опыта и предпочтений вашей команды.
Например, если вашей команде необходимо создавать проекты, требующие больших объемов данных, на уровне предприятия, для которых требуется безопасная, надежная и комплексная структура с большим набором компонентов, которые хорошо работают друг с другом, Ext JS by Sencha — отличный вариант. Вам никогда не придется выходить за рамки поиска компонентов. Для проектов, которые начинаются с малого, но нуждаются в гибкости и возможностях масштабирования, Vue может хорошо подойти. И если ваша передовая команда имеет большой опыт работы с React, то лучшим выбором будет использование React.
Достаточно большое количество задач в верстке сейчас можно сделать при помощи фреймворков — это сильно упрощает процесс верстки, ускоряет его и минимизирует количество ошибок. Особенно это касается задач, которые нужно выполнить очень быстро. Мы подробно рассказываем про самые популярные фреймворки для верстки и разбираем их плюсы и минусы.
Bootstrap
Bootstrap на сегодняшний день является одним из самых популярных CSS-фреймворков — с его помощью создано около 22% всех сайтов в мире. Чаще всего его используют для создания адаптивных сайтов, а также мобайл-ферст сервисов. Сейчас последней версией фреймворка является Bootstrap 5. Документацию к Bootstrap вы можете почитать здесь.
Плюсы Bootstrap
Адаптивная сетка Bootstrap
Благодаря Bootstrap разработчикам и верстальщикам не нужно тратить рабочее время на создание собственной сетки — сервис позволяет автоматически построить адаптивную сетку, основанную на Flex-модели. При этом пользователи могут как менять эту адаптивную сетку под свои нужды, так и оставить версию по умолчанию, потому что она будет самостоятельно меняться в зависимости от наполнения контейнеров контентом и особенностям сайта.
Адаптивные изображения
Bootstrap поставляется со своим кодом для автоматического изменения размера изображений в зависимости от текущего размера экрана пользователя. Для этого нужно просто добавить к изображениям класс .img-responsive — все остальное сделают стандартные правила CSS.
Компоненты Bootstrap
Bootstrap поставляется с огромным набором компонентов, которые можно легко использовать. Среди них:
- Панели навигации
- Выпадающие списки
- Индикаторы прогресса
Мало того, что можно легко добавить эти элементы на сайт, так они еще и будут адаптироваться в зависимости от размера экрана или устройства, с которого их будут просматривать. Более полный список добавляемых функций можно найти в документации к Bootstrap.
JavaScript в Bootstrap
Тем, кому не хватает возможностей Bootstrap, сервис позволяет использовать JS. Это дает разработчикам еще больше возможностей для интерактивности.
Документация Bootstrap
Документация у Bootstrap — одна из лучших на рынке. Каждый фрагмент кода подробно описан и объяснен.
В пояснения также включены примеры кода для базовой реализации, что упрощает процесс внедрения Bootstrap даже для начинающих верстальщиков и разработчиков. Все, что нужно сделать для встраивания необходимого элемента — выбрать компонент, скопировать и вставить код на свою страницу, после чего настроить его.
Настраиваемость Bootstrap
Когда дело доходит до таких фреймворков как Bootstrap, одной из главных проблем является их размер — их вес может замедлять первую загрузку страницы. Например, текущая версия CSS-файла Bootstrap весит 119 КБ, что достаточно много.
Bootstrap позволяет настраивать, какую функцию пользователи собираются встроить в свою загрузку. Можно просто отменить загрузку функций, которые не нужны для работы данного сайта — это снижает вес CSS-файла и ускоряет время загрузки страницы.
Сообщество Bootstrap
Как и во многих опенсорс-проектах, за Bootstrap стоит большое сообщество дизайнеров и разработчиков. Размещение на GitHub позволяет разработчикам легко изменять кодовую базу Bootstrap и вносить в нее свой вклад. Это позволяет core-team в Bootstrap действительно понимать, чего не хватает пользователям их продукта, и быстро реализовывать необходимые фичи.
Внешние шаблоны Bootstrap
По мере роста популярности Bootstrap другие разработчики начали создавать шаблоны на основе этого фреймворка, чтобы еще больше ускорить процесс веб-разработки. Сейчас существуют тысячи шаблонов, готовых компонентов и тем для Bootstrap — по сути, можно создать очень качественный собственный сайт, практически не написав ни строчки CSS-кода.
Продолжайте учиться: На Хекслете есть профессия Верстальщика — в ней вы узнаете как основы HTML и CSS, так и самые современные технологии и концепции для верстки. В этой профессии изучается и Bootstrap
Минусы Bootstrap
Непонятный синтаксис Bootstrap
В самом начале знакомства с Bootstrap некоторые детали его синтаксиса могут сбивать с толку. Например, в системе сеток для того, чтобы создать столбец, занимающий треть экрана, нужно добавить к нему класс .col-md-4. При этом интуитивно сначала кажется, что вместо четверки нужно поставить тройку — ведь мы говорим о трети экрана, а не о четверти. Однако Bootstrap использует систему из 12 столбцов, а 4 — это треть из 12, поэтому такая логика имеет право на существования, хотя первоначально кажется очень неинтуитивной.
Файлы начальной загрузки очень большие
Мы уже писали об этом выше — CSS-файлы Bootstrap весят достаточно много, и опытные разработчики могут вручную сгрузить ненужные им функции. Однако начинающим программистам это сделать самостоятельно практически нереально.
Tailwind
Плюсы Tailwind
Tailwind легко настраивается
У фреймворка есть файл с конфигурацией по умолчанию tailwind.config.js, в котором можно настроить цветовые палитры, стили, темы и так далее.
Tailwind имеет собственные служебные шаблоны
Это решает множество проблем, начиная с определения классов и их организацию, заканчивая неймингом классов. Такие служебные классы сильно упрощают процесс создания пользовательских компонентов — теперь не нужно прям погружаться в разработку или верстку, можно просто применить функцию theme() и все заработает.
Интеграция с PurgeCSS
Этот фреймворк можно оптимизировать с помощью PurgeCSS. С его помощью можно уменьшить размер файла, отсканировав HTML и удалив неиспользуемые классы. Обычно, по мере увеличения размера проекта, размер файла CSS тоже увеличивается — однако это не происходит у Tailwind из-за стандартизированного набора классов и настроенной оптимизации. Однако такая возможность есть и у других фреймворков, просто у Tailwind эта функция наиболее оптимизирована.
Адаптивность
Tailwind позволяет создавать сложные адаптивные макеты, которые будут в первую очередь ориентированы на мобильные устройства. При этом аналогичная функция есть и у Bootstrap.
Коммьюнити
У Tailwind огромное и очень открытое сообщество, где можно всегда задать вопросы и найти решения той или иной проблемы.
Прокачивайте свой уровень программирования: На Хекслете есть несколько десятков треков — специальных курсов для опытных программистов, позволяющие повысить уровень компетентности разработчика в разных направлениях.
Минусы Tailwind
Огромное количество классов, которые не используются
Слишком большое количество классов — как ни странно это звучит и как бы не противоречило это предыдущему пункту — это тоже один из минусов. Дело в том, что у вас всегда будет огромное количество классов и стилей, которые вы никогда не будете использовать: при этом их придется пролистывать, думать о них. Да, это все будет оптимизировано через PurgeCSS, однако огромный выбор может оказаться достаточно сложным, особенно для начинающих разработчиков.
Практики написания кода
Tailwind приучает пользователей писать стили inline.
Material-UI
Material-UI — библиотека с открытым кодом, которая включает в себя компоненты React , реализующие Material Design от Google. Она построена с использованием Less (Leaner Style Sheets) — обратно совместимым языковым расширением для CSS. Запустившись в 2014 году — вскоре после того, как появился React, Material-UI набрал более 68 тыс. звезд на GitHub и на сегодняшний день является чуть ли не лучшей библиотекой для пользовательских интерфейсов для React.
Плюсы Material-UI
Документация
Material-UI имеет очень подробную документацию. Это сильно упрощает навигацию по фреймворку и полностью раскрывает все его возможности.
Регулярные обновления
Фреймворк Material-UI постоянно обновляется — разработчики развивают проект и активно расширяют его функционал, убирая ошибки
Хороший вкус
Все компоненты в Material-UI едины по дизайну и цветовым тонам. Такой подход позволяет разработанному приложению или сайту выглядеть очень эстетично.
Минусы Material-UI
Мутабельность
Разработчики жалуются, что библиотека удобна на небольших проектах. Тогда как при росте продукта некоторые компоненты начинают мутировать и это практически невозможно быстро решить.
Проблемы с производительностью
Тоже проблема, которая касается разработчиков больших проектов со сложными алгоритмами и большим количеством различных компонентов.
Принадлежность к экосистеме Google
До конца непонятно, хорошо это или плохо — но Material-UI все-таки является библиотекой, которую активно продвигает Google. Это следует учитывать разработчикам, которые хотят создавать платформенно-независимый UX (например, приложение, которое должно хорошо работать и на iOS).
Foundation
сайт Foundation, можно увидеть надпись «Самый продвинутый в мире адаптивный интерфейсный фреймворк» — и, в общем, это является не только маркетинговым лозунгом. Foundation был разработан так, чтобы естественно сочетаться с фреймворком Rails — и поэтому он перенял несколько «буддийских» руководящих принципов Rails.
Foundation — это адаптивный интерфейсный фреймворк, который представляет собой адаптивную сетку, а также компоненты пользовательского интерфейса HTML и CSS, шаблоны и фрагменты кода. Сюда же входит вся типографика, формы, кнопки, навигация и другие элементы интерфейса, а также дополнительные функции, которые предоставляются JavaScript.
При этом Foundation — проект с открытым исходным кодом, который ранее поддерживала компания ZURB. С 2019 года этот проект поддерживают только волонтеры.
Сейчас Foundation не имеет такого же влияния на фронтенд-разработчиков, как Bootstrap или хотя бы Tailwind, однако сейчас этот фреймворк постепенно начинает набирать обороты и распространяться среди программистов и верстальщиков. Например, согласно данным BuiltWith, 11,8% из 100 тыс. лучших сайтов используют Bootstrap. И 2,3% — Foundation Framework.
Foundation имеет модульную структуру и состоит в основном из стилей Sass. По сути, фреймворк построен на основе сетки в 940 пикселей, которая является адаптивным макетом.
Плюсы Foundation
Большое количество инструментов
Технически не очень верно утверждать, что Foundation — это CSS-фреймворк. Изначально он создавался как модульный набор инструментов, предназначенных для решения практически всех видов интерфейсных задач. В Foundation есть отдельные инструменты для веб-сайтов, отдельные — для электронной почты и так далее. Также Foundation поставляется с интерфейсом командной строки — это очень порадует разработчиков, которые привыкли работать с Webpack или другими сборщиками модулей.
Гибкость
В отличие от Bootstrap, Foundation был создан для того, чтобы предоставить разработчику полный контроль над своим пользовательским интерфейсом. В результате Foundation будет казаться новичку чрезвычайно сложным. Однако причина в том, что Foundation не навязывает разработчику какой-либо язык стилей, а стремится быть тем, чем он является: отличным фреймворком CSS.
Больше, чем просто элементы интерфейса
Помимо элементов для интерфейсов, Foundation имеет большое количество дополнительных возможностей — расширенную систему адаптивных изображений, готовый компонент ценовой таблицы (да, тот, который применяют для отображения различных тарифных планов), проверку формы, адаптивные встраивания и многое другое.
Минусы Foundation
Небольшое сообщество
У Foundation достаточно небольшое сообщество, и найти разработчика, который знает Bootstrap, все же намного проще. Поэтому и найти решение сложной задачи тоже сложнее на Foundation, чем на Bootstrap.
Сложность
Если разработчик привык к Bootstrap или к ванильному CSS, Foundation будет казаться очень и очень сложным. Слои внутри слоев, компоненты с компонентами, бесконечные возможности настройки. Но это вытекает из плюсов Foundation, поэтому с этим стоит смириться.
Кошмар для перфекционистов
В Foundation есть огромное количество различных вариаций и инструментов — можно практически вечно доделывать ваш продукт, не внося никаких изменений.
UIkit
UIkit — совсем небольшой фреймворк, который специализируется на минимализме — не в функциях, а в дизайне. Если вам нравятся сверхчистые, элегантные и не лишенные пробелов дизайны, то UIkit вам поможет. Особенно UIkit помогает разработчикам для приложений.
Но UIkit — достаточно автономная система, поэтому ее нельзя расширять или изменять. При этом как и Bootstrap, UIkit работает со своим JavaScript. Это значит, что вы можете использовать jQuery для манипуляций с DOM, но использование виртуальной структуры DOM, такой как React — невозможно.
По сути, UIkit — комплект готовых компонентов для различных частей сайтов.
Поэтому мы не будем широко расписывать возможности UIkit, а просто скорее добавим, что это прекрасный фреймворк для очень простых задач, которые вам нужно быстро решить.
Никогда не останавливайтесь: В программировании говорят, что нужно постоянно учиться даже для того, чтобы просто находиться на месте. Развивайтесь с нами — на Хекслете есть сотни курсов по разработке на разных языках и технологиях
1. Ant Design
Ant-компоненты позволяют разработчикам экономить время. Например, благодаря готовым компонентам форм, разработчику не придется возиться с их созданием форм и валидацией.
Также Ant Design экономит время дизайнеров. Ко всем компонентам приложены файлы Sketch и Figma.
Компоненты Ant Design поддерживают и JSX, и TypeScript. Есть поддержка хуков. Документация Ant Design ясная и понятная, в ней много хороших примеров.
2. Material-UI
В Material-UI вы найдете больше ста компонентов. Кроме того, там есть больше тысячи иконок.
Библиотека предоставляет файлы Sketch, Figma иAdobe Xd для дизайнеров (правда, на платной основе).
Документация у библиотеки хорошая, содержит примеры кода.
Material UI используется в таких компаниях, как Spotify, NASA, Netflix и Amazon.
3. Chakra UI
Chakra UI предоставляет набор React-компонентов, которые отличаются доступностью и пригодностью для компоновки и многократного использования. Создавать сайты и приложения с их помощью можно очень быстро.
Компоненты Chakra UI соответствуют спецификациям WAI-ARIA и имеют aria-* атрибуты.
Эта библиотека отличается хорошей производительностью, а кроме того с ней приятно работать. Благодаря этому сообщество Chakra UI быстро растет.
Библиотека имеет хорошую документацию с примерами кода.
4. React Bootstrap
React Bootstrap делает возможным использование Bootstrap JS для React-компонентов.
В этом пакете вы найдете все компоненты Bootstrap, которые мы используем с JavaScript. Они созданы с нуля на React и не содержат jQuery.
React Bootstrap имеет тщательно продуманную документацию с примерами кода.
5. Semantic UI React
Если для вашего React-приложения нужен Semantic UI, обратите внимание на эту интеграцию.
6. Fluent UI
Fluent UI разработана Microsoft. Дизайн Fluent используется для устройств и инструментов Windows 10 и Windows 11.
Платформа имеет коллекцию утилит, React- и веб-компонентов для создания веб-приложений. Документация хорошая.
7. Evergreen
Evergreen содержит больше 30 компонентов. Документация тоже производит хорошее впечатление.
8. Reactstrap
9. Grommet
В Grommet вы найдете больше 60 компонентов. Он также предоставляет Sketch, Figma, AdobeXd файлы и больше 600 иконок.
Этот фреймворк используется Netflix, Samsung, Uber, Boeing, IBM и другими компаниями.
10. Reakit
11. Mantine
Mantine содержит больше ста настраиваемых компонентов и хуков.
Заключение
Использование UI-библиотек позволяет экономить время и снижает необходимость в большем количестве зависимостей. Конечно, таких библиотек значительно больше, чем представлено в этом списке. Мы собрали лишь самые широко используемые. Надеемся, вам они пригодятся.
От редакции Techrocks. Возможно, вас также заинтересуют другие статьи о React:
Читайте также: