AngularUniversal无法从Firebase获取数据。
创始人
2024-10-29 21:01:24
0

使用Angular的TransferState模块来在服务器端和客户端之间传递数据。这样可以避免Firebase数据在服务器端已经被获取,但是在客户端还没有获取的情况。

在服务端代码中添加以下代码:

import 'rxjs/add/operator/do';
import { of } from 'rxjs/observable/of';
import { fromPromise } from 'rxjs/observable/fromPromise';
import { map } from 'rxjs/operators/map';
import { AngularFireDatabase } from '@angular/fire/database';
import { TransferState, makeStateKey } from '@angular/platform-browser';

const dataKey = makeStateKey('my-data');

app.get('/', (req, res) => {
  const data = server.getSomeData(); // 从服务端获取数据

  const existingData = transferState.get(dataKey, null); // 从TransferState中获取数据,如果不存在则返回null

  if (existingData) {
    return of(existingData).subscribe(html => res.send(html)); // 如果已经存在数据,则直接返回
  } else {
    return fromPromise(firebase.getData()) // 如果不存在数据,则使用Firebase获取数据
      .pipe(
        map(data => {
          transferState.set(dataKey, data); // 将获取的数据存储到TransferState中
          return data;
        })
      )
      .subscribe(html => res.send(html)); // 最后返回数据
  }
});

在客户端代码中添加以下代码:

import 'rxjs/add/operator/take';
import { TransferState, makeStateKey } from '@angular/platform-browser';

const dataKey = makeStateKey('my-data');

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html'
})
export class AppComponent implements OnInit {
  data: any;

  constructor(private transferState: TransferState, private db: AngularFireDatabase) {}

  ngOnInit() {
    const existingData = this.transferState.get(dataKey, null); // 从TransferState中获取数据,如果不存在则返回null

    if (existingData) {
      this.data = existingData; // 如果已经存在数据,则直接使用
    } else {
      this.db
        .object('/data')
        .valueChanges()
        .take(1) // 只获取一次数据
        .subscribe(data => {
          this.transferState.set(dataKey, data); // 将获取的数据存储到TransferState中
          this.data = data; // 最后使用数据
        });
    }
  }
}

相关内容

热门资讯

今天下午!hhpoker为什么... 今天下午!hhpoker为什么一直输(透视)新挑战辅助脚本(一贯是有辅助app)-哔哩哔哩1、用户打...
透视积累!佛手在线是不是有挂(... 透视积累!佛手在线是不是有挂(透视)哈糖大菠萝怎么挂(辅助)竟然真的有软件(哔哩哔哩)佛手在线是不是...
出乎意料的是!wepokerp... 出乎意料的是!wepokerplus作必弊(透视)牛总管辅助神器(真是真的是有辅助神器)-哔哩哔哩所...
透视教程书!佛手在线大菠萝为什... 您好,佛手在线大菠萝为什么都输这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054...
透视了解!wepoker作必弊... 透视了解!wepoker作必弊方法(透视)新道游app辅助器(其实真的有辅助辅助器)-哔哩哔哩1)新...
透视积累!德州局透视(透视)红... 透视积累!德州局透视(透视)红龙poker辅助(辅助)切实一直都是有技巧(哔哩哔哩)1、打开软件启动...
透视机巧!哈糖大菠萝软件下载(... 透视机巧!哈糖大菠萝软件下载(透视)悦扑克脚本(辅助)竟然有神器(哔哩哔哩)1、哈糖大菠萝软件下载有...
透视黑科技!德扑圈有透视吗(透... 透视黑科技!德扑圈有透视吗(透视)陕西三代二破解(都是是有辅助软件)-哔哩哔哩1、陕西三代二破解公共...
透视步骤!佛手在线大菠萝为什么... 透视步骤!佛手在线大菠萝为什么都输(透视)德州透视是真的假的(辅助)都是是有插件(哔哩哔哩)1、佛手...
围绕透视问题!aapoker免... 围绕透视问题!aapoker免费透视脚本(透视)一起宁德钓蟹辅助怎么设置(果然是有辅助插件)-哔哩哔...