[Разработка мобильных приложений] Как выбрать мобильную кросс-платформу в 2021 году (перевод)

Автор Сообщение
news_bot ®

Стаж: 6 лет 9 месяцев
Сообщений: 27286

Создавать темы news_bot ® написал(а)
26-Фев-2021 06:31


Кросс-платформенные решения - тренд в мобильной разработке. Уже есть различные технологии от PWA до Flutter и Kotlin Multiplatform. Как выбрать среди них?Новый развивающийся бизнес зачастую в первую очередь ориентируется на мобильные технологии: социальные сети, необанкинговые решения, приложения для электронной коммерции, такси и другие. Новый бизнес ориентирован на экономическую эффективность, поэтому переход на кросс-платформенность для разработки мобильного приложения кажется правильным выбором. Посмотрим, что будет в 2021 году и как выбрать правильную технологию.Познакомимся с Женей
Евгения — солюшн-архитектор. Она должна решить, как построить новое мобильное приложение для изучения английского языка не носителями: людьми из Турции, Италии или России. Давайте посмотрим, как Женя подходит к этой задаче.Приложение должно включать в себя богатую анимацию, уметь воспроизводить и записывать аудио, показывать видео с субтитрами, а также статические и динамические изображения.В компании — владельце приложения также ожидают, что разработкой будет заниматься единая команда — как для Android- и iOS-приложений, чтобы свести к минимуму усилия по передаче знаний и максимизировать скорость команды. В будущем также планируют запустить веб-приложения. А еще в компании хотели бы упростить будущий найм.Прогрессивные веб-приложенияЖеня начинает свои исследования. Она гуглит «мобильные веб-приложения» и находит статью. В ней упоминаются «Прогрессивные веб-приложения» (PWA). Что это такое?
Прогрессивные веб-приложения — это, по сути, веб-сайты, которые используют специальные API для доступа к определенным возможностям устройства. Эти API позволяют получить доступ к памяти на устройстве, интегрируются с Push Notifications (на Android) и, что самое важное, работать в отдельной вкладке браузера. Еще их можно установить на устройство «иконкой», как настоящее приложение. Звучит неплохо! Давайте посмотрим на плюсы и минусы PWA:Плюсы:
  • Всем занимается одна команда.
  • Достаточно навыков веб-разработки.
  • Легко обслуживать.
  • Все работает сразу из коробки.
Минусы:
  • Нет пушей на iOS.
  • Неудобный UX.
  • Ограниченная поддержка.
  • Трудно найти — пользователи скачивают приложение в сторах.
А вот и хорошая табличка, показывающая доступность PWA в разных браузерах:
Гибридные приложенияЖене не нравится, что PWA обладают ограниченной поддержкой пушей. Поэтому она гуглит дальше.
Она обнаруживает гибридный подход: давайте поместим наш сайт в WebView в реальном нативном приложении. Оказывается, можно поместить свой мобильный сайт со всем его HTML, CSS и JS-кодом в ресурсы приложения. Затем вы помещаете WebView в корневой ViewController/Activity приложения и указываете на эти ресурсы.Пользователи смогут найти приложение в Google Play и AppStore, чего не было в случае с PWA. А еще, если вам нужны дополнительные возможности, вы можете легко добавить их — ведь у вас настоящее приложение, для этого уже есть необходимые фреймворки.Плюсы:
  • Высокая скорость работы.
  • Настоящая кросс-платформенность.
  • Можно пользоваться практически всеми преимуществами нативных приложений.
Минусы:
  • UX не очень (ведь перед нами по-прежнему сайт в шкуре приложения).
  • Небольшое сообщество разработчиков.

Архитектура гибридного приложенияПримеры таких приложений: Appcelerator, Ionic, Apache Cordova.Нативные кросс-платформенные приложения
Большой недостаток гибридных приложений — плохой UX. Поскольку это все еще браузер в мобильном приложении, он подтормаживает.Евгения все еще пытается получить единую кодовую базу для своего решения, но при этом решить проблему с вялым UX. Поэтому она читает больше про нативные кросс-платформенные фреймворки.Xamarin
Xamarin — это решение на основе .NET от Microsoft. Xamarin (или NET 5.0) помогает сделать кросс-платформенное приложение используя C# и .NET в мобильном приложении. Xamarin Forms (или MAUI) — это библиотека для построения пользовательского интерфейса в таких приложениях.
Плюсы:
  • Легко разрабатывать в компаниях с сильной экспертизой в технологиях Microsoft.
  • Полностью кросс-платформенное.
  • Потенциально можно сделать его и веб-приложением.
Минусы:
  • 2 виртуальные машины в приложении на Android - JVM и Mono
  • Мало инструментов и библиотек
  • Долгое время исправления багов в Xamarin
  • Растет размер бандлов
React NativeReact Native создан для того, чтобы привнести React в мобильные технологии. И это действительно хорошо сработало! Согласно статистике Bitrise, React Native занимает 13% рынка. Его также используют более 500 тысяч репозиториев на «Гитхабе».
React Native использует языки Javascript или TypeScript для разработки приложений и транслирует компоненты React Native в компоненты платформы. Так, превращается в TextView на Android.Приложение включает в себя JavaScript VM для выполнения JS-кода логики и пользовательского интерфейса приложения. React Native также умеет работать с API платформы. С такой архитектурой можно создать любое приложение, даже мобильную игру.
Плюсы:
  • Большое сообщество.
  • Пользуются в Skype, Discord, Shopify, Tesla, Artsy.
  • Доступны нативные возможности приложений.
  • Можно писать на React.
Минусы:
  • Долгое время запуска.
  • Экстеншены и работа в фоне требует написания нативного кода.
  • Проходит внутренний редизайн
Flutter
Flutter — это кросс-платформенный фреймворк с открытым исходным кодом от Google, основанный на языке Dart. В отличие от React Native, Flutter использует свой собственный 2D-движок для отрисовки пользовательского интерфейса в нативном виде. Такой подход обеспечивает независимость от версии ОС, на которой работает приложение. Flutter приложение также компилирует Dart в нативный для платформы код в релизной сборке, таким образом в рантайме Dart VM становится не нужна. Советую нашей Жене мое подробное сравнение Flutter и React Native.Flutter привлек к себе большое внимание, собрал более 100 000 звезд, а количество приложений, собранных с его помощью, продолжает стремительно расти. Согласно той же статистике Bitrise, уже 9% билдов в прошлом году собраны на Flutter. Это очень много для такой молодой технологии.Плюсы:
  • Хорошая производительность
  • Декларативный UI
  • Поддерживает веб
Минусы:
  • Ненативный UI
  • Малопопулярный язык Dart.
  • Недостаток некоторых инструментов (например, в плане контроля безопасности).
Kotlin MultiplatformXamarin, Flutter и React Native позволяют вам написать практически весь код единожды и запускать его и на iOS, и на Android.
Kotlin Multiplatform делает иначе. KMP считает, что пользовательский интерфейс сильно зависит от платформы и самого устройства (скажем, планшета или веб-сайта). Однако бизнес-логика остается практически неизменной. Почему бы не переиспользовать прежде всего ее?Итак, с KMP у вас все еще есть два нативных приложения, которые пользуются одной бизнес-логикой. Вы можете использовать все, что угодно в пользовательском интерфейсе: будь то родной Android Views, JetPack Compose или Swift UI для iOS. Вы даже можете использовать Flutter или React Native для вашего пользовательского интерфейса! Он все равно будет прекрасно работать с Kotlin Multiplatform. Вот несколько примеров.
Плюсы:
  • Родной язык для разработчиков Android.
  • iOS разработчикам нетрудно читать Kotlin код.
  • Единая среда разработки для Android и iOS.
  • Подходит для реализации веб-приложений.
Минусы:
  • Молодое решение, все еще в альфа-версии.
  • Нельзя переиспользовать UI.
Что же выбрать?Итак, наша Женя собирается выбрать свое решение. Вот что мы ей посоветуем:
  • Согласна на мобильный сайт вместо приложения, несмотря на ограничения в UI? Тогда — PWA.
  • В компании все пишут на .NET? Значит, Xamarin.
  • Основной стек — это JS/TypeScript? Выбираем React Native.
  • Будем шарить между приложениями не UI, а только бизнес-логику? Значит, Kotlin Multiplatform.

Конечно, это не все критерии: например, мы не рассмотрели доступность разработчиков на рынке или темы поддержки новых версий OS. Но основной алгоритм - выше :)Удачи, Женя!
===========
Источник:
habr.com
===========

===========
Автор оригинала: Vladimir Ivanov
===========
Похожие новости: Теги для поиска: #_razrabotka_mobilnyh_prilozhenij (Разработка мобильных приложений), #_flutter, #_reactnative, #_xamarin, #_kotlin_multiplatform, #_blog_kompanii_tinkoff (
Блог компании TINKOFF
)
, #_razrabotka_mobilnyh_prilozhenij (
Разработка мобильных приложений
)
Профиль  ЛС 
Показать сообщения:     

Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах
Вы не можете прикреплять файлы к сообщениям
Вы не можете скачивать файлы

Текущее время: 22-Ноя 19:24
Часовой пояс: UTC + 5