Фоновое изображение
Продаём тимлиду идею Server/Backend-Driven UI

Привет, меня зовут Андрей Гончаров, я Frontend Developer в Mish Product Lab. Сегодня подробно разберёмся, что такое Server/Backend-Driven UI, как с ним работать и зачем он вообще нужен.

Что такое Backend-Driven UI?

Backend-Driven UI (или Server-Driven UI) — это концепция в разработке приложений с интерфейсом, при котором бэкенд управляет как данными приложения, так и его внешним видом. Например, для фронтенд-приложения BDUI будет управлять версткой.

Есть разные уровни «проникновения» этой концепции в фронтенд-приложение, но лучше это представить как спектр.

Да, кстати, об этом статью сейчас не написал только ленивый.

Кейсы

Проще всего эту концепцию представить через кейсы. Вот парочка:

Кейс #1: страница оформления заказа (aka checkout)

Обычно заказ оформляется в несколько шагов: выясняем способ получения, способ оплаты, контактные данные, делаем оплату. Бизнесы бывают разные, и логика формирования шагов такая же. Шаги же, по сути, представляют собой формы с полями ввода. На фронтенде нам нужно организовать отрисовку полей форм, переходы между шагами и отправку данных. Остальная логика возлагается на бэкенд.

Яркий пример — CS-Cart.

Примерная логика формирования шагов чекаута в интернет-магазинах.

Кейс #2: пост в блоге

Обычно посты в блогах пишут в админке блога в WYSIWYG-редакторе. Некоторые современные редакторы предоставляют многоколоночное оформление контента, кастомные компоненты, накидывают SEO, тегов и прочих ништяков. Бэкенд хранит записи, организует управление и доступ к ним. Фронтенд из структуры документа формирует верстку.

Яркий пример – Strapi.

Кейс #3: быстрая доставка улучшений интерфейса без обновления приложения

Представим, что вы — банк, который оказался под санкциями: ваше приложение скрыли из всех магазинов, вы не можете доставить пользователям новые обновления. Но у вас есть выход, ведь весь интерфейс приложения приходит в виде JSON с сервера!

Яркий пример — DivKit.

Зачем реализовывать эти кейсы при помощи данной концепции?

Потому что мы хотим:

  • Значительно поменять Layout фронтенд-приложения (кейс #3)
  • Изменить структуру какого-то экрана в приложении (кейс #3).
  • Внедрить A/B-тестирование (кейс #3, кейс #1). Представьте, какая это боль, когда такие тесты на гипотезы надо писать руками, деплоить в отдельные версии/бандлы и так далее.
  • Срочно добавить дополнительное промо от отдела маркетинга.
  • Добавить страничку с каким-то контентом.

Что может пойти не так, если отказаться от BDUI

Для каждого отдельного члена команды свой сценарий развития событий:

  • Для проджекта нужно будет учитывать сложность изменения структуры страницы. Конечно, есть тимлид, который подскажет. Но что, если он тимлид-джун без опыта?
  • Для тестировщиков изменение глобальных частей с захардкоженной структурой практически всегда триггерит полный регресс. Нет уверенности в том, что полный ручной регресс не вызывает боль. Но точно есть сценарий с отсрочкой релиза на пару дней.
  • Для программистов можно выделить следующие больные моменты кратко:
  • изменения в структуре нужно зафиксировать в коде, то есть сесть и сверстать
  • внешние источники данных нужно интегрировать для новых блоков;
  • необходимо контролировать удаление источника данных при удалении блока;
  • нужно встроить новый блок в существующую верстку или же адаптировать верстку при удалении блока.

Что насчет сроков? Негативный кейс

Давайте рассмотрим кейс, в котором у нас заказывают небольшой сервис бронирования койко-мест. У нас есть дизайн, по которому мы верстаем, есть договор, определяющий функционал и сроки. Есть реальная действительность, где перед дедлайном просят поменять местами промоблок и компонент «селектор койки».

Казалось бы, в верстке меняешь два компонента местами — готово. Но есть вероятные технические блокеры:

  • фронтендер мог верстать страницу изначально с этими блоками, делая хардкод в размерах, отступах и так далее;
  • источники данных могут требовать какой-то определенный порядок запроса данных;
  • код может быть «грязным», а понимающий его синьор — в отпуске.

Ещё есть минус от хардкоженной структуры UI, не очень очевидный: у страницы нет контракта с точки зрения его структуры и данных. Мы можем понять, какие данные придут, но только после изучения кода. Как и узнать раскладку блоков в верстке.

А как быть с добавлением новой страницы с текстовым контентом?

  • Нужно залезть в код и скопировать типовую страничку с её layout — по сути копипаст бойлерплейта.
  • Может потребоваться зарегистрировать страницу в роутере приложения, закрыть за авторизацией.
  • Необходимо подрубить источник данных.

С такой ментальной моделью приложения сложно будет сделать следующее:

  • Проводить A/B-тестирование.
  • Добавлять новый контент на сайт без привлечения отдела разработки.

Иными словами, фронтенд превращается в программу, внешний вид которой не поддается изменению извне, он не зависит от какой-то схемы.

По сути, вся техника Backend-Driven UI сводится к получению схемы экрана от бэкенда, к дальнейшей обработке и рендерингу. Часто даже с получением карты сайта.

Как получить удобный BDUI

Что нам нужно учитывать, чтобы получить удобный Backend-Driven UI?

  • Контракт от бэкенда.

    Нужно понимать, в каком формате будет приходить лейаут экрана.
  • Начальное состояние компонента.

    Если оно нужно, то как лучше его инкапсулировать?
  • Степень, до которой BDUI описывает layout.

    Сюда входит расположение и вложенность блоков, их горизонтальное или вертикальное расположение на странице, размеры блоков.
  • Параметры страницы.

    Среди них номер страницы, фильтры и так далее.

Как это сделать?

Лучше всего, как я выяснил, выделять логику формирования интерфейса в отдельный микросервис, Backend For Frontend. Не стоит запихивать в бэкенд проекта логику для полиморфного отображения. Да, есть случаи как в кейсе #1, но мы сейчас про макет.

Кто и как применяет в индустрии BDUI?

Пример #1. Бигтех, Ozon

Приложение Ozon для смартфонов сделано по этой концепции. Применяют они её по ряду причин:

  • для A/B-тестирования;
  • чтобы вытащить бизнес-логику из Web/Android/iOS приложений;
  • для более быстрой доставки изменений пользователям.

Вот классная статья, где они рассказывают о том, как готовили логику формирования интерфейса: Как работает Backend-Driven UI на мобильном клиенте

Скриншот приложения с пояснениями по виджетам на страницы, скрин из статьи Ozon.

Пример #2. Бигтех, Альфа

Хорошая статья на Хабре, где инженеры Альфа-банка делятся своим опытом: Эволюция Server-Driven UI: динамические поля, хэндлеры и многошаг

Отмечу, что они рассказывают не столько про компоновку, сколько про всё остальное: обработка событий, бизнес-логика в сложных формах.

Сриншот из статьи с примером обработки событий.

Пример #3. Бигтех, Airbnb

Ныне почивший в России букинг-сервис Airbnb. Да, их мобильное приложение также построено на концепции BDUI. Применяют они её для A/B-тестирования. Вот приправленная кодом статейка с их рецептом: A Deep Dive into Airbnb’s Server-Driven UI System

Вот так Airbnb трансформирует данные в UI. Скрин из их статьи.

Пример #4. No-code, Unflow

Да, такая модная тема как no-code зачастую заходит в клиентские приложения через BDUI. Так, Unflow оставляет свободу для кастомизации и предоставляет SDK для мобильных платформ: Unflow

Вот как выглядит редактор экранов в Unflow.

Пример #5. No-code, Strapi

Интересный пример реализации — Strapi, Headless CMS. Она даёт интерфейс для редактирования контента и не формирует отображения, не генерирует сайт. Так можно создать сущность «макет страницы» и в него накидывать блоки страницы. Но это совсем неудобно. И ещё нет возможности удобно впилить другие источники данных.

Админка Strapi.

Пример #6. Реализация концепции в CMS CS-Cartт

Есть другой пример реализации, так называемый Block Manager. По сути, это упрощенный визуальный редактор макета страницы. Позволяет собрать/пересобрать страничку, вообще не прибегая к написанию кода. Настройки блоков/виджетов — отдельная мультивселенная.

Редактор макетов страницы.

Выводы

Backend/Server-Driven UI всё же узкоспециален. Реализация полноценного интерфейса в такой парадигме — задание со звёздочкой в квадрате, готовое съесть много денег бизнеса. Поэтому отлично заходит этот подход либо для очень крупного, либо для малого бизнеса. Да и выглядит это как некий Trade-off в обоих случаях.

  • Очень крупному бизнесу нужно проверять гипотезы, быстро поставлять фичи/заплатки и не сгореть в аду дублирующейся бизнес-логики в разных клиентских приложениях.
  • У малого бизнеса нет ресурсов для своих решений, эти ребята берут no-code платформы, которые в основном BDUI, накидывают экраны, настраивают open-source клиент на свой инстанс в платформе, и всё работает.

Но концепция хороша, и применять её точечно в определенных местах (типа сложных форм) — однозначно правильное решение. Чем больше бизнес-логики на сервере, и меньше на клиенте — тем крепче спится.

Загружаем ещё...