Angular Universal: избегайте перезапуска анимации CSS при замене DOM

У нас есть веб-страница, которая начинается с анимации: коара

Из соображений производительности и SEO мы обычно предварительно преобразовываем наши страницы в статический HTML с помощью Angular Universal.

Проблема здесь: анимация перезапускается, когда DOM заменяется кодом Angular. Есть ли способ избежать этого или подождать с заменой DOM, пока анимация не закончится (и не запускать ее снова)?

Вы нашли решение этой проблемы? У меня такая же проблема. Хороший сайт кстати :)

Vingtoft 14.11.2019 15:49

@Vingtoft Думаю, в конце концов мы удалили эту анимацию.

chris08002 24.03.2020 11:35
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
3
2
264
1

Ответы 1

Вы можете добавить поддельного провайдера в свой app.module.ts, чтобы знать, где отображается компонент:

 providers: [
    {
      provide: "isBrowser",
      useValue: true,
    },
  ],

и этот импорт на вашем app.server.module.ts

 providers: [
    {
      provide: "isBrowser",
      useValue: false,
    },
  ],

Затем вы можете импортировать этого «провайдера» в свой компонент следующим образом:

constructor(@Inject("isBrowser") public enableAnimations: boolean) {}

Теперь вы можете отключить анимацию при загрузке компонента на стороне сервера и добавить анимацию на стороне клиента.

Однако это не решает следующие проблемы: запустите анимацию в предварительно обработанном HTML-коде, а затем не запускайте ее снова в HTML-коде, отображаемом на стороне клиента. Любые предложения для этого?

chris08002 25.03.2019 16:40

Другие вопросы по теме