我已成功安装并成功使用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如果我解决了这个问题或找到了好的文档,我会再次更新它。 :)
答案 0 :(得分:-1)
本文介绍了如何在angular universal中进行后端调用。 https://angular.io/guide/universal#absolute-http-urls
答案 1 :(得分:-1)
您需要在模块中设置passThruUnknownUrl: true
。此外部api调用后的forRoot将起作用。
HttpClientInMemoryWebApiModule.forRoot(
InMemoryDataService, { dataEncapsulation: false, passThruUnknownUrl: true }
)