Angular. Functions & getters в шаблонах

Если в шаблоне Angular компонента использовать метод или getter, то он будет выполняться на каждый цикл механизма обнаружения изменений, что может привести к проблемам с производительностью. Цель обнаружения изменений - выяснить, какие части пользовательского интерфейса необходимо перерисовать. Чтобы определить есть изменение или нет, требуется выполнить функцию и сравнить её с текущим результатом.

Применение ChangeDetectionStrategy.OnPush позволяет локализовать проблему на уровне компонента, но не избавится от неё.

Решение

Есть 2 способа.

  1. Результат функции присвоить свойству компонента
  2. Использовать pure pipe (в случае чистых функций можно быть уверенным, что результат не изменился).

Более подробно про pure pipe в материале Faster Angular Applications - Part 2. Pure Pipes, Pure Functions and Memoization или его видеоверсии

Важное замечание

Проблемы с производительностью возникает на большом количестве элементов (несколько тысяч) или на частых перерисовках (realtime графики). Поэтому в большинстве случаев использование методов и getter'ов является адекватным решением.

Небольшое обсуждение такого замечания в twitter


Похожие записи

Angular. Can't set breakpoints in VS Code

Вариант решения проблемы, когда не срабатывают точки остановки при разработке Angular приложений в редакторе VS Code
10 апреля 2018 г. в Angular

@Directive v/s @Component in Angular

Компоненты создают DOM элементы и добавляют к ним поведение, а директивы только добавляют поведение к существующим DOM элементам

13 августа 2018 г. в Angular

Angular attribute setter

Пример задания значения булева Input свойства как директивы, на примере:

09 октября 2018 г. в Angular

Angular. Отличие baseHref от deployUrl

  • deployUrl - задаёт путь для статических (js, css) файлов в index.html.
  • baseHref - определяет base, используется в ссылках и маршрутизации (routing) Angular