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; // 最后使用数据
        });
    }
  }
}

相关内容

热门资讯

透视肯定!aapoker真的假... 透视肯定!aapoker真的假的(透视)透视方法(一贯真的有挂)aapoker真的假的是一种具有地方...
透视辅助!aapoker透视怎... 透视辅助!aapoker透视怎么用(透视)透视脚本下载(确实真的是有挂)1、进入到aapoker透视...
透视玄学!aapoker如何设... 透视玄学!aapoker如何设置胜率(透视)透视脚本(确实是真的有挂);1.aapoker如何设置胜...
透视ai代打!aapoker透... 透视ai代打!aapoker透视脚本(透视)ai插件(一贯是有挂);1、任何aapoker透视脚本a...
透视神器!aapoker怎么开... 透视神器!aapoker怎么开辅助器(透视)发牌逻辑(原来有挂)在进入aapoker怎么开辅助器辅助...
透视模拟器!aapoker透视... 透视模拟器!aapoker透视脚本下载(透视)透视脚本(切实存在有挂)进入游戏-大厅左侧-新手福利-...
透视工具!aapoker辅助软... 透视工具!aapoker辅助软件合法吗(透视)透视脚本入口(总是有挂)1、打开软件启动之后找到中间准...
透视好友房!aapoker怎么... 透视好友房!aapoker怎么提高中牌率(透视)透视插件(本来是真的有挂)1、下载好aapoker怎...
透视代打!aa poker透视... 透视代打!aa poker透视软件(透视)透视脚本(其实真的是有挂)1、操作简单,无需注册,只需要使...
透视辅助!aapoker真的假... 透视辅助!aapoker真的假的(透视)辅助插件工具(竟然真的有挂);1)aapoker真的假的辅助...