Angular5 Server端渲染,外部Api数据服务在ssr中不起作用

问题描述 投票:3回答:2

我已经设置并成功使用了Angular5 + SSR。它仍然很不错。

所有组件都适用于SSR和非SSR。并且有一些服务调用外部HTTP get apis来获取一些数据。当然,它在非SSR模式下运行良好。

但是,问题是在SSR上,节点服务器确实支持获取和呈现数据。我只能在客户端获取和渲染后看到获取的数据。

import {Injectable} from '@angular/core';
import { HttpClient, HttpHeaders } from '@angular/common/http';
import 'rxjs/add/operator/map';
import {Observable} from "rxjs";

const httpOptions = {
    headers: new HttpHeaders({ 'Content-Type': 'application/json' })
};

@Injectable()
export class BannerService {

    constructor(public http: HttpClient){
        console.log('SmsService Initialized...');
    }

    getBanners(){
        return this.http.get(BASE_API_URL + '/getData', httpOptions);
    }
}

home.component.ts

import {Component, OnDestroy, OnInit} from '@angular/core';
import { Router } from "@angular/router";
import {Subscription} from "rxjs/Subscription";
import {BannerService} from "../../services/banner.service";

@Component({
    selector: 'app-home',
    styleUrls: ['home.container.css'],
    templateUrl: 'home.container.html'
})

export class HomeContainerComponent implements OnInit, OnDestroy {

    public horizontalBannerList1;
    public horizontalBannerList2;
    public verticalBannerList;
    private bannerList;

    constructor( private router: Router, private bannerService: BannerService){
         ...
    }

    ngOnInit() {
        this.initBannerList();
    }

    ngOnDestroy() {
       ...
    }

    initBannerList(){

        if(this.bannerList){
            return;
        }

        this.bannerService.getBanners().subscribe(
            result => {
                console.log("bannerList result : ", result);
                this.bannerList = result;    
            },
            error => {
                console.error("bannerList error: ", error);
            },
            () => {
                console.log("bannerList completed");
            });
    }

}

我期望在SSR上节点服务器调用http请求数据并在index.html上呈现它,但它不是....

我错过了还是被误解了?

ps:报告了相同的问题。 https://github.com/angular/universal/issues/674如果我解决这个问题或找到好的文档,我会再次更新它。 :)

angular serverside-rendering angular-universal
2个回答
-1
投票

本文介绍了如何在angular universal中进行后端调用。 https://angular.io/guide/universal#absolute-http-urls


-1
投票

您需要在模块中设置passThruUnknownUrl: true。 forRoot在此外部api调用之后将起作用。

 HttpClientInMemoryWebApiModule.forRoot(
      InMemoryDataService, { dataEncapsulation: false, passThruUnknownUrl: true }
    )
© www.soinside.com 2019 - 2024. All rights reserved.