Архитектура одностраничных приложений набрала обороты благодаря популярности реактивных фреймворков: VueJS, ReactJS, AngularJS.

Все больше компаний стремятся отделить логику Backend и Frontend приложений, опираясь на принципы микросервисной архитектуры.

Разберемся, чем рендеринг на стороне клиента (CRR) отличается от серверного (SSR).
Серверный рендеринг происходит в четыре этапа. Допустим, вы ввели в адресной строке URL и зашли на сайт:

  • Сервер отдает клиенту готовый к рендерингу HTML ответ
  • Браузер рендерит полученный HTML и загружает JS код. На этом этапе страница доступна к просмотру
  • Браузер исполняет JS код, а вместе с ним и код Vue/React
  • Страница становится интерактивной

image
При клиентском рендеринге страница доступна после выполнения кода. Благодаря чему пользователь не видит голый, не оживленный JS-ом скелет страницы:

  • Сервер присылает ответ клиенту
  • Браузер загружает JS
  • Браузер исполняет Vue/React
  • Страница доступна и интерактивна

Способ показа страницы пользователю не единственное различие CSR и SSR. Нередко маршрутизация SPA тоже делается на клиенте. У этого подхода есть недостатки с точки зрения CEO, но об этом дальше. Сначала рассмотрим преимущества SPA.

Преимущества одностраничных приложений


Новый подход не получил бы такого распространения, не имея существенных преимуществ

  • Выше скорость работы приложения
  • Лучше User Experience
  • Меньше нагрузка на сервер
  • Универсальная платформа
  • Отзывчивый интерфейс

Скорость


Благодаря внутренним оптимизации VDOM скорость обновления нод на странице выше, чем при использовании VanillaJS. В реактивных фреймворках используются и другие оптимизации, которые повышают отзывчивость интерфейса и улучшают user experience.

Сервер


Благодаря клиентской маршрутизации снижается нагрузка не сервер. Сервер не отдает заново набор повторяющихся скриптов и контента. При переходе между страницами вся работа по отрисовке контента делегирована JS. Фактически происходит эмуляция постраничной навигации. С точки зрения сервера страница остается такой же.

Универсальность


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

Архитектура одностраничных приложений


Фреймворки для создания одностраничных приложений реализуют MVC паттерн, позволяя разделить клиентское приложение на модель, представление и контроллер.


Контроллер


Контроллер обрабатывает действия пользователя и меняет состояние приложения. Контроллер отвечает не только за навигацию, но и обработку пользовательских событий: кликов, отправки форм, текстового ввода и т.п.
При проектировании Vue приложения лучше создать 1 компонент-контейнер, в который эмитятся пользовательские события. Он импортируется в качестве компонента в routes.js

routes.js



Модель


Модель отвечает за хранение и работу с данными. В качестве хранилища данных во Vue используются Vuex, Vue Apollo, EventBus, RxJS. Взаимодействие с API для удобства выносится в отдельных файл. Взаимодействие с хранилищем происходит в компонентах.

Представление


Представление во Vue — это шаблон, заключенный в тэг template. Представление отвечает за отрисовку данных пользователю.
Одностраничные приложения делятся по способу рендеринга на client side rendering и server side rendering.

Преимущества клиентского рендеринга


  • Не перезагружает контент страницы при постраничной навигации
  • После первоначальной загрузки работа с контентом происходит быстрее
  • Удобно для работы в режиме development благодаря горячей перезагрузке

Противниками CSR выступают CEO-специалисты. Одностраничное CSR приложение плохо индексируется поисковыми роботами.

Преимущества серверного рендеринга


Для SSR в экосистеме Vue существует библиотека vue-server-renderer:

  • Загрузка страницы быстрее, чем CSR
  • Лучше для SEO
  • Время первичной отрисовки контента ниже так, как не ожидается загрузка JS
  • Взаимодействие с сайтом происходит быстрее благодаря клиентской навигации VueJS
  • Нет необходимости в излишних запросах к серверу, которые происходят при первоначальной загрузке страницы при клиентском рендеринге

Главный недостаток CSR — проблемы индексации в поисковых системах. Google с 2015 года начал индексировать CSR страницы. Проблема заключается в том, что поисковику приходится самостоятельно рендерить страницу и дожидаться финального HTML. Этот процесс может занять около недели.

Что выбрать?


Нередко компании настраивают 2 варианта билда одностраничных приложений: CSR и SSR. Их используются в зависимости от задач и потребностей бизнеса. Решение о способе рендеринга одностраничных приложений выносится на основании запросов бизнеса. Для некоторых приложений СЕО-оптимизация не является критичной. Их создатели делают ставку на отзывчивость интерфейса, удобство разработки.

При выборе SSR для VueJS лучше воспользоваться NuxtJS. Это минималистичный фреймворк с доступной документацией.