Angular - TransferState - страница загружается дважды (мигает) - PullRequest
0 голосов
/ 26 апреля 2018

У меня небольшая проблема с модулем Angular 5.2.10 TransferState.В настоящее время я использую Angular Universal (последняя версия), чтобы сделать мой сайт более удобным для SEO.Все работает нормально, кроме одного ... Сначала страница загружается - на стороне сервера, затем контент исчезает и загружается на стороне браузера (экран).

blink

Я создал сервис для реализации TransferState (вы можете увидеть его ниже).

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import "rxjs/add/operator/map";
import 'rxjs/add/observable/of';
import 'rxjs/add/operator/share';
import { Observable } from 'rxjs/Observable';
import { TransferState, makeStateKey, DomSanitizer, SafeHtml } from '@angular/platform-browser';

interface pageData {
    banner: string;
    data: any;
    html: SafeHtml;
    text: string;
    title: string;
}

@Injectable()
export class ServerService {
    constructor(private http: HttpClient, private state: TransferState, private sanitizer: DomSanitizer) { }

    getResponse(url): Observable<any> {
        url = makeStateKey<Promise<any>>(url);

        let temp = this.state.hasKey(url);
        if (!temp)
            return this.http.get<any>(url).map(
                (response: any) => {
                    let data = response;
                    this.state.set(url, data);
                    return data;
                }
            ).share();
        else {
            return Observable.of(this.state.get(url, null as Observable<any>));
        }
    }

    async getResponseAsync(url): Promise<any> {
        let temp = await this.state.hasKey(url);
        url = makeStateKey<Promise<any>>(url);

        if (!await temp)
            return this.http.get<any>(url).toPromise().then(
                async (response: any) => {
                    await this.state.set(url, await response);
                    return await response;
                }
            );
        else {
            return await this.state.get(url, null as Promise<any>)
        }
    }
    }

Я также пробовал решение с TransferHttpCacheModule, но проблема остается.

main.ts

import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';

if (environment.production) {
  enableProdMode();
}

document.addEventListener('DOMContentLoaded', () => {
  platformBrowserDynamic()
    .bootstrapModule(AppModule)
    .catch(err => console.log(err));
});

app.server.module.ts

 import { NgModule } from '@angular/core';
import { ServerModule, ServerTransferStateModule } from "@angular/platform-server";
import { ModuleMapLoaderModule } from '@nguniversal/module-map-ngfactory-loader';
import { AppModule } from './app.module';
import { AppComponent } from './app.component';
import { NoopAnimationsModule } from '@angular/platform-browser/animations'; 


@NgModule({
  imports: [
    AppModule,
    ServerModule,
    ServerTransferStateModule,
    ModuleMapLoaderModule,
    NoopAnimationsModule,
  ],
  providers: [],
  bootstrap: [ AppComponent ],
})
export class AppServerModule {}

app.module.ts

// Core
import { BrowserModule, BrowserTransferStateModule } from '@angular/platform-browser';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { NgModule } from '@angular/core';
import { RouterModule, Routes, PreloadAllModules } from '@angular/router';
import { ServiceWorkerModule } from '@angular/service-worker';
import { FormsModule, ReactiveFormsModule, NgForm } from '@angular/forms';
import { NgForageModule, NgForageConfig, NgForageOptions } from "ngforage";
import { NgProgressModule } from '@ngx-progressbar/core';

// Config
import { Config } from './config';


// Compontents
import { AppComponent } from './app.component';
import { ContainerComponent } from './components/container/container.component'


import { ContainerModule } from './components/container/container.module'


// Environment
import { environment } from '../environments/environment';
import { NotfoundComponent } from './components/notfound/notfound.component';
import { NotfoundModule } from './components/notfound/notfound.module';



const routes: Routes = [
  {
    path: '',
    pathMatch: 'full',
    redirectTo: '/pl'
  },

  {
    path: 'pl/home',
    redirectTo: 'pl'
  },
  {
    path: '404',
    component: NotfoundComponent
  },
  {
    path: ':lang',
    component: ContainerComponent
  },
  {
    path: ':lang/:index',
    component: ContainerComponent,
  },
    {
    path: '**',
    redirectTo: '404'
  }

];


@NgModule({
  declarations: [
    AppComponent,
  ],
  imports: [
    RouterModule.forRoot(routes, { initialNavigation: 'enabled', preloadingStrategy: PreloadAllModules }),
    BrowserModule.withServerTransition({ appId: 'main-app' }),
    BrowserTransferStateModule,
    ServiceWorkerModule.register('/ngsw-worker.js', { enabled: environment.production }),
    BrowserAnimationsModule,
    NgProgressModule.forRoot(),
    NgForageModule.forRoot(),
    ContainerModule,
    NotfoundModule,
  ],
  providers: [
    Config
  ],
  bootstrap: [AppComponent]
})



export class AppModule{
  constructor(ngfConfig: NgForageConfig) {
    ngfConfig.configure({
      name: 'apiDB',
      driver: [ // defaults to indexedDB -> webSQL -> localStorage -> sessionStorage
        NgForageConfig.DRIVER_INDEXEDDB,
        NgForageConfig.DRIVER_LOCALSTORAGE
      ]
    });
  }
}

Пример репо вы можете увидеть там (некоторые компоненты устарели - самые важные модули, которые у вас есть выше)

Знаете ли вы, как решить эту проблему?Или это основная ошибка, и я должен ждать исправлений?

Страница мигает, после вставки узла состояния в дерево документа (этот отмечен ниже main-app-state)

enter image description here

Edit Это также не проблема Service Worker, я пытался отключить его, но все равно.

Github проблема здесь

...