2 заметки с тегом

angualarjs

Архитектура фронтенда: смена фреймворка

В предыдущей части я рассказал, почему хорошо создавать конфигурации — JSON-описания поведения страниц без программирования.

У этого подхода есть ещё один прекрасный плюс: смена фреймворка перестаёт быть невыполнимой задачей.

Если вы используете конфигурации, то компоненты страницы внутри шаблона могут быть написаны на любом фреймворке: AngualrJS 1.x, Angular, Vue.js, React, Svelte и так далее. Вы даже можете их смешивать, и переписывать пошагово, когда часть компонентов использует один фреймворк, а часть — другой.

Таким образом, продукт и компания перестают быть связаны устаревшими технологиями, и если фреймворк перестанет поддерживаться, работа не остановится. Конечно, переезд не станет лёгким делом и займёт несколько месяцев, но без конфигураций страниц переехать будет просто невозможно без переписывания каждой страницы вручную. Именно так и получаются ситуации, когда в одном проекте есть Бекбон, Джейквери, Реакт разных версий и только избранные разработчики могут без страха менять что-то в легаси-модулях.

Про терминологию

Казалось бы, что специальная техническая терминология должна помогать пониманию ситуации между специалистами. Ну когда не нужно говорить: «вот эта хреновина», и с помощью простого словосочетания становится понятнее, и легче.

Но на деле к этому примешивается другое:

  • терминология звучит круто и как бы говорит каждому, кто с ней не знаком, что он просто дурак;
  • совершенно не обязательно, что тот, кто о ней говорит, понимает, что же это значит.

Из своего опыта могу вспомнить, когда люди говорили мне: «о, ну нет, это же плохо, у нас нет Третьей нормальной формы в БД!» или «А это точно MVC?». На поверку оказывалось, что ребята сами плохо понимали, что же это такое, когда я просил объяснить своими словами. Хотя, конечно, MVC и Третья нормальная форма — это крутые идеи сами по себе.

Так и с речью вообще. Например, документация к AngularJS 1 написана сухим техническим языком, а к Vue.js — для всех в стили «ну смотри, здесь как-то так работает». И пытаясь научиться чему-то с первым ангуларом, ты чувствуешь себя самозванцем постоянно, а пытаясь сделать что-то на вью — исследователем. И когда я после вью вернулся на первый ангулар, я обнаружил, что там всё так же просто, хотя документация пытается убедить в обратном. Да вы и сами сравните, статью из документации об одном и том же (по смыслу и предназначению) механизме:

Слоты во Vue.js
ngTransclude в AngualarJS 1.x

Да там даже одна и таже штука называется простым словом Слот и сложным Трансклюд!