Задать вопрос
Ответы пользователя по тегу Angular
  • Как организовать ленивую загрузку внешних скриптов в Angular 2+ (CLI)?

    NightBuster
    @NightBuster Автор вопроса
    Решил так:

    Написал сервис-загрузчик для скриптов:

    import { Injectable } from '@angular/core';
    import { Observable } from 'rxjs/Observable';
    import { Observer } from 'rxjs/Observer';
    
    @Injectable()
    export class ScriptLoaderService {
    
      private scripts: ScriptModel [] = [];
    
      public load(script: ScriptModel): Observable<ScriptModel> {
        return new Observable<ScriptModel>((observer: Observer<ScriptModel>) => {
          const existingScript = this.scripts.find(s => s.name === script.name);
    
          // Complete if already loaded
          if (existingScript && existingScript.loaded) {
            observer.next(existingScript);
            observer.complete();
          } else {
            // Add the script
            this.scripts = [...this.scripts, script];
    
            // Load the script
            const scriptElement = document.createElement('script');
            scriptElement.type = 'text/javascript';
            scriptElement.src = script.src;
    
            scriptElement.onload = () => {
              script.loaded = true;
              observer.next(script);
              observer.complete();
            };
    
            scriptElement.onerror = (error: any) => {
              observer.error('Couldn\'t load script ' + script.src);
            };
    
            document.getElementsByTagName('body')[0].appendChild(scriptElement);
          }
        });
      }
    
    }
    
    export interface ScriptModel {
      name: string;
      src: string;
      loaded: boolean;
    }
    Ответ написан
    Комментировать