Ключевые выводы
-
- Flutter — это фреймворк для кроссплатформенной разработки приложений.
- Особенности Flutter — высокая производительность, приятный и понятный UI, а также активное сообщество разработчиков.
- Из недостатков — Flutter может не подойти для сложных приложений, у него непривычный интерфейс, а ещё некоторые нативные модули с его помощью встроить не получится.
- К преимуществам Flutter относят быстрое прототипирование, низкую стоимость разработки и единый дизайн для разных платформ.
Что такое Flutter?
Flutter — популярный кроссплатформенный фреймворк для разработки приложений. Компания Google создала набор инструментов с открытым исходным кодом, чтобы разработчики могли создавать приложения для iOS, Android, Windows, Mac, Linux и веб. Для всех этих платформ пишут один код. И приложения выглядят точь-в-точь как нативные.
Кроссплатформенная разработка значительно сокращает время и стоимость создания приложений.
Всё это делает Flutter отличным выбором для фаундеров стартапов, которым важно охватить как можно больше пользователей и при этом не разориться.
Фреймворк Flutter написан на языке программирования Dart. Это быстрый и интуитивно понятный язык, поэтому разработчикам легко к нему адаптироваться. А с помощью JIT-компиляции (англ. Just-in-Time) можно менять код и сразу видеть изменения, что делает процесс работы быстрее.
От многих других фреймворков Flutter отличает уникальный подход к построению пользовательских интерфейсов.
Flutter использует виджеты — блоки для создания интерактивного UI.
Разрабатывать приложения на Flutter становится намного проще благодаря обширной библиотеке готовых виджетов. А еще можно создать кастомные.
Еще одна полезная фича — горячая перезагрузка (англ. hot reload). Так разработчики могут мгновенно увидеть изменения в коде и им не нужно все переделывать. Они чувствуют себя свободнее к экспериментам. Это полезная функция для фаундеров, которые хотят быстро итерировать и дорабатывать свои приложения.
Flutter сочетает в себе мощные инструменты, быстрый язык программирования и кроссплатформенные возможности, за что его так любят стартаперы. Но так было не всегда. Фреймворк прошел несколько важных этапов развития, о которых мы сейчас поговорим.
Эволюция фреймворка Flutter
Flutter развивался быстрыми темпами. В него постоянно вносили улучшения, что позволило ему закрепиться в авангарде разработки приложений. Чтобы оценить его текущее состояние, посмотрим на эволюцию этого инновационного фреймворка с момента его появления.
В 2015 году Flutter был представлен под названием Sky. В первую очередь он был направлен на достижение высокой производительности и качества рендеринга. Он был заточен под разработку интерфейсов Android-приложений, которые потянут 120 кадров в секунду. Это стало основой того, что мы сегодня знаем как Flutter, — фреймворка, в котором по-прежнему важны производительность и совершенство UI.
В мае 2017 года Flutter был впервые представлен на конференции разработчиков Google I/O. Основные усилия разработчиков пошли на стабилизацию основных функций и расширение библиотеки виджетов. Несмотря на относительную новизну, потенциал фреймворка был очевиден, что привлекло внимание сообщества.
В декабре 2018 года Google объявил о выпуске Flutter 1.0. Фреймворк сильно продвинулся и перешел на модель опенсорс. По релизу можно было судить, что Flutter стабильно работает и полностью совместим с такими популярными IDE, как Visual Studio Code и Android Studio. Библиотека виджетов пополнилась новыми элементами и анимациями.
Flutter 2.0
В марте 2021 года была выпущена версия Flutter 2.0. Пожалуй, самым значительным нововведением стала поддержка десктопных и веб-приложений. В бета-версии Flutter 2.0 стало возможным создавать программы для macOS, Windows и Linux, что способствовало развитию кроссплатформенности. Фреймворк подстраивается под язык дизайна каждой платформы, поэтому приложения на Flutter выглядят как нативные на разных устройствах.
Flutter 3.0
В феврале 2022 года выпустили Flutter 3.0. В это время в Dart появилась новая функция — нулевая безопасность. Она помогает разработчикам избежать ошибок, связанных с нулевыми ссылками. Это делает код более надежным и простым в обслуживании. Кроме того, Google ввели поддержку телефонов-раскладушек и девкит для разработки казуальных игр. Также компания внесла некоторые изменения в API: например, удалила устаревшие API и внедрила ZoomPageTransitionsBuilder.
В следующих разделах этой статьи мы подробнее рассмотрим плюсы и минусы использования Flutter для ваших проектов.
Преимущества Flutter для разработки приложений
У инновационного UI-фреймворка от Google есть много преимуществ. Обсудим, почему Flutter может стать отличным выбором для разработки вашего приложения.
Ускоренная разработка
Создание приложения на Flutter обычно занимает около 4–5 месяцев. Технология Flutter основана на виджетах, поэтому разработчики могут применять объектно-ориентированное программирование к любому элементу. Это значительно ускоряет процесс. Скорость разработки растет еще и за счет функции горячей перезагрузки. Она нужна, чтобы обновлять и перестраивать приложение быстрее.
Продукт для нескольких платформ
Flutter-разработчикам нужно написать всего один код для приложения, которое будет работать на нескольких платформах (Android, iOS, десктоп и веб). Это не только оптимизирует разработку, но и значительно сокращает расходы. Дешевле будет как программировать, так и поддерживать продукт после запуска. С Flutter фаундеры стартапов могут воплотить идею в жизнь и не растратить все финансовые ресурсы проекта.
Производительность как у нативного приложения
Flutter может обеспечить такую же производительность приложений, как и специализированные языки программирования (Java для Android и Swift для iOS). В отличие от некоторых фреймворков, которые основаны на мостах JavaScript, Flutter гарантирует отличный UX без ущерба для производительности.
По эффективности он не уступает своему ближайшему конкуренту — React Native. Для владельцев продуктов это означает, что их приложение будет не только выглядеть как нативное, но еще и работать плавно и бесперебойно. И количество довольных пользователей будет расти.
Приятный и кастомный интерфейс
Хотите красивый и понятный интерфейс? Тогда используйте Flutter. Разработчики могут создать эстетически привлекательный кастомный дизайн на ваш вкус. Так продукт будет соответствовать требованиям брендинга. Кроме того, Flutter обеспечивает плавную работу анимации, что делает приложение удобнее.
Сильное комьюнити и поддержка от Google
Постоянное развитие Flutter обусловлено неизменной приверженностью Google этому фреймворку. Компания оперативно исправляет все ошибки и проблемы с кодом, чтобы всем было удобно работать. А еще сообщество разработчиков Flutter способствуют развитию фреймворка — специалисты выгружают в сеть полезные ресурсы и примеры кода. Как владелец продукта, можете быть уверены, что ваше приложение выиграет и от поддержки Google, и от коллективных знаний верного комьюнити.
Сложности в использовании Flutter для разработки
Хотя у разработки на Flutter много преимуществ, некоторых сложностей в работе избежать не получится. Чтобы это не стало неожиданностью, разберем, что может пойти не так.
Непривычный интерфейс
С одной стороны, работать с виджетами очень удобно. Но с другой, своеобразный подход Flutter к разработке UI может потребовать от команд адаптации. Это создает трудности при создании веб- и мобильных приложений, особенно для тех, кто только начинает работать с фреймворком.
Нельзя встроить некоторые нативные функции
Наверное, главный недостаток фреймворка — ограниченный доступ к некоторым нативным модулям. Команде разработчиков может потребоваться использовать родной код, например, при работе с tvOS, watchOS, Android Auto или CarPlay.
Может не подойти для сложных приложений
Хотя кастомные виджеты и крутые анимации улучшают пользовательский опыт, они могут усложнить процесс разработки. В плоскости масштабных проектов это приводит к увеличению сроков создания ПО. К тому же, много анимаций замедляют работу приложения и могут снизить его производительность.
Flutter всё ещё развивается
Flutter — новый фреймворк, и количество доступных библиотек и инструментов пока ограничено. Особенно если сравнивать с более известными аналогами. Flutter часто обновляется, поэтому разработчикам нужно мониторить изменения и адаптировать код, чтобы он был совместим с последними версиями. Кроме того, Flutter for Web сейчас находится на стадии бета-версии, а значит, он не полностью стабилен. Веб-разработчики могут столкнуться с багами при работе с ним.
Несмотря на сложности, Flutter любят за скорость разработки, высокую производительность, привлекательный UI и сильную поддержку сообщества.
Решить, стоит ли использовать Flutter для разработки приложений, можно только взвесив все плюсы и минусы фреймворка. А чтобы стало еще понятнее, рассмотрим несколько примеров.
Для каких проектов используют Flutter
Разработка на Flutter привлекает своей универсальностью, широкими возможностями и кроссплатформенностью. Но надо определить, в каких ситуациях она будет выгодным решением. Можно выделить несколько случаев, когда Flutter будет особенно полезен.
Кейс 1: Кроссплатформенная мобильная разработка
Встречайте Эмили, девушку, которая хочет сделать экологичный образ жизни доступным для всех. Эмили, основательнице стартапа EcoMate, пришла в голову идея создать приложение, которое помогло бы людям заботиться о природе. Она хочет, чтобы ее приложение было доступно как можно большему числу пользователей. Эмили решила создать приложение и для iOS, и для Android, поэтому она выбрала Flutter для кроссплатформенной мобильной разработки.
Эмили и ее команда использовали архитектуру Flutter. Основанный на виджетах дизайн помог создать красивый кастомный интерфейс. Функция горячей перезагрузки сделала разработку гибкой и быстрой. Приложение EcoMate запустили в App Store и Google Play. Оно работает стабильно и эффективно на обеих платформах, а пользователям нравится простой интерфейс и интересный контент.
Можете почитать о том, как мы в Purrweb создали похожее эко-приложение.
Кейс 2: Улучшаем пользовательский опыт с Flutter
Знакомьтесь: Джеймс, руководитель команды разработчиков в компании Artscape. Она специализируется на цифровом искусстве. Джеймс хочет создать революционную торговую площадку для NFT (англ. non-fungible token). В его планах создать удобный и визуально привлекательный NFT-маркетплейс, доступный коллекционерам и художникам на различных платформах. Он стремится обеспечить единообразие как на мобильных устройствах, так и на ПК, а также разработать веб-приложение.
Джеймс выбрал Flutter, поскольку кастомный интерфейс, который можно создать с помощью этого фреймворка, точно будет соответствовать его видению. В приложении можно изучать, покупать и продавать NFT, участвовать в аукционах и общаться с единомышленниками. Платформа получила положительные оценки за дизайн.
Наша компания также следит за тенденциями в финансовой индустрии. Если интересно, почитайте о том, как мы создали криптовалютный кошелек.
И Эмили, и Джеймс — вымышленные персонажи, у каждого своя идея и ее воплощение. Но их объединяет выбор Flutter, который помог им создать классные приложения, отвечающие их запросам.
Подведем итоги: если вы хотите ускорить разработку и написать один код для всех платформ, используйте Flutter.
А еще с ним вы снизите затраты на разработку и пост-релизную поддержку и создадите приятный и понятный UI. И производительность приложения будет высокой.
Как дела у Flutter в 2023?
Начиная с этого раздела, мы будем рассказывать о фреймворке Flutter с технической точки зрения. Расскажем о его популярности среди разработчиков и особенностях работы. А еще рассмотрим популярные приложения, созданные на Flutter.
Все больше разработчиков останавливают свой выбор на Flutter. Фреймворк захватывает рынок все более быстрыми темпами. По данным исследования Statista, проведенного в 2022 году, Flutter стал кроссплатформенным фреймворком разработки № 1. Исследование Stack Overflow Developer Survey 2022 подтверждает результаты опроса Statista: на первом месте по популярности находится фреймворк Flutter, за ним следует React Native.
На графике показано, что с момента запуска Flutter стабильно набирает популярность. В 2021 году он обогнал React Native по количеству запросов в поисковиках. По прогнозам, эта тенденция сохранится в 2024 году, и Flutter продолжает развиваться благодаря регулярным обновлениям.
Flutter может похвастаться сильной поддержкой активного сообщества пользователей по всему миру, он используется тысячами разработчиков. В начале 2023 года Flutter достиг 150 000 звезд на GitHub — пользователи показали одобрение проекта и интерес к нему. Такое количество звезд свидетельствует о популярности и востребованности Flutter.
Чем Flutter отличается от других фреймворков?
Flutter отличается от аналогов по нескольким параметрам. Например, Flutter использует объектно-ориентированный язык программирования Dart, в то время как React Native использует JavaScript, а Cordova — HTML, CSS и JavaScript. Код на Flutter компилируется в нативный код, что дает прямой доступ к компонентам устройства. Это повышает производительность и скорость рендеринга, если сравнивать с работой с мостами в React Native.
Flutter позволяет кастомизировать виджеты, в то время как у React Native и Cordova есть ограничения по настройке нативных компонентов. А еще на Flutter цикл разработки быстрее, чем на React Native, благодаря функции горячей перезагрузки. При работе с Cordova, разработчикам нужно больше времени на создание и тестирование приложений по сравнению с этими двумя фреймворками.
В таблице мы сравнили React Native, Flutter и Cordova по некоторым ключевым характеристикам.
Характеристика | React Native | Flutter | Cordova |
Язык программирования | JavaScript | Dart | HTML, CSS, JavaScript |
Производительность | Максимально 58 FPS (англ. frames per second, кадров в секунду),
использование CPU составляет 11.7% |
Стабильные 60 FPS, или 120 FPS, если устройство позволяет. Использование
CPU — 5.4% |
Точных данных нет, в целом медленнее, чем Flutter и React Native |
Кастомизация UI | Нативные виджеты, кастомные компоненты из сторонних библиотек | Просто кастомизировать благодаря архитектуре на основе виджетов | Для создания интерфейсов используют WebView, доступа к нативным элементам нет |
Скорость разработки (в среднем) | 4-6 месяцев | 2-3 месяца | 3-4 месяца |
Популярность | Не так популярен, как Flutter, его выбирают 32% разработчиков | Самый популярный, 46% разработчиков используют Flutter | Уступает по популярности Flutter и React Native, его выбирают 10% разработчиков |
Flutter — это мощный и универсальный инструмент с большим количеством преимуществ перед другими фреймворками. Хотя React Native и Cordova по-прежнему популярны, они постепенно уступают Flutter.
Популярные приложения на Flutter
Многие известные и влиятельные бренды использовали Flutter для разработки приложений. Приложения из совершенно разных сфер выигрывают благодаря возможностям Flutter. И крутые примеры повышают интерес к фреймворку.
Google Ads & Google Pay
Google Ads и Google Pay создали на Flutter для того, чтобы на Android и iOS был одинаковый интерфейс. Так пользователям проще ориентироваться в приложениях. Поскольку Flutter — изобретение Google, сама компания выступает крупнейшим спонсором этой технологии. Корпорация обеспечивает постоянную поддержку и развитие фреймворка и на собственном примере показывает, насколько он может быть полезен.
Google Ads — мобильное приложение для PR-менеджеров. В нем можно запускать и отслеживать рекламные кампании. Более 80% компаний по всему миру используют Google Ads для проведения PPC-кампаний. Доля рынка этого приложения — целых 92%.
Google Pay — одно из самых известных и надежных приложений для онлайн-платежей. В мире насчитывается более 150 миллионов пользователей. Google Pay уже занял лидирующие позиции на 42 рынках, и его используют 2 193 компании по всему миру.
SpaceX Go
SpaceX Go — приложение для отслеживания запусков ракет. В нем собрано всё о прошедших и предстоящих запусках SpaceX. Приложение отправляет уведомления пользователям перед тем, как ракета покинет стартовую площадку. Так они смогут зайти и посмотреть новости в нужное время.
SpaceX Go не может работать без точной и актуальной информации от компании SpaceX. Приложение должно регулярно обновляться и учитывать все изменения в расписании запусков. Отличным способом закрыть эту потребность стало использование функции горячей перезагрузки — разработчики вносят изменения в режиме реального времени без перезапуска приложения.
eBay Motors
eBay Motors — дочерняя компания eBay — это площадка для торговли уникальными автомобилями и запчастями. Пользователи могут выбрать машину, пообщаться с продавцом и заключить сделку — все в одном приложении.
Перед командой eBay Motors стояла задача создать приложение для iOS и Android в сжатые сроки. Столкнувшись с ограничениями бюджета и времени, команда решила использовать Flutter. Он помог сократить время разработки вдвое за счет использования одного кода для двух версий.
Как мы в Purrweb работаем с Flutter
Не только IT-гиганты как Google или eBay, но и IT-стартапы разрабатывают удобные приложения на Flutter. Purrweb занимается разработкой уже давно, и в нашем портфолио есть проекты на Flutter. Расскажем про эти проекты.
Post-a-room — приложение для поиска комнаты в аренду
Мобильное приложение Post-a-room помогает найти комнату в аренду. Оно было создано для исследования рынка недвижимости в Лондоне. Клиентам было нужно приложение, чтобы собрать статистику по спросу и предложению на рынке и узнать стоимость аренды в разных районах.
В приложении есть две роли — арендодатель и арендатор. Они могут общаться через приложение перед тем как встретиться для подписания договора. Это не первое наше приложение для рынка недвижимости, поэтому мы уверены в его качестве. Но Post-a-room необычное с точки зрения функций. Ждем релиза, чтобы узнать, выполнит ли оно свою роль.
Мобильное приложение Kem
Мобильное приложение Kem — это сервис для онлайн-платежей и обмена валют. Клиенты попросили разработать MVP, которое они могли бы показать банкам. Так они планировали привлечь инвестиции. Наша команда создала приложение, с помощью которого пользователи могут отправлять деньги людям из списка контактов. Безопасность обеспечивают PIN-код и надежный платежный шлюз. Пользователи могут редактировать профиль и просматривать историю транзакций. Сейчас мы ждем, когда банки откроют доступ к своим API, чтобы завершить работу над приложением.
Резюмируем
Фреймворк Flutter изменил подход к разработке приложений. Она становится быстрее, проще и дешевле, а результат — красивее. Итак, стоит ли использовать Flutter для разработки приложений?
Flutter считается одним из лучших вариантов — кроссплатформенность, высокая производительность и крутые кастомные интерфейсы не могут остаться незамеченными. Функция горячей перезагрузки ускорила процесс создания прототипов и итераций, и теперь можно быстрее вывести приложение на рынок. Кроме того, у Flutter активное сообщество и сильная поддержка со стороны Google.
Несмотря на многочисленные преимущества, Flutter не поддерживает некоторые нативные модули, а разработка приложений для масштабных проектов может быть сложной и невыгодной. Разработчикам также может потребоваться время для адаптации к работе с виджетами.
Тем не менее Flutter может быть решением, которое вы ищете. Заполняйте форму, и мы расскажем о разработке приложений на индивидуальной консультации. Наша команда будет рада помочь воплотить вашу идею в жизнь.