AsyncAwait在第一次调用时无法在NextJS/ReactFirebase/Firestore上工作
创始人
2024-09-21 02:30:14
0

这个问题通常出现在使用firebase / firestore API进行数据获取的情况下。root cause在于初次加载进入页面时,服务端渲染 (SSR) 使我们的getInitialProps在服务端被调用从而导致我们的异步代码不会执行。因此我们需要在客户端的componentDidMount周期内进行,判断当前页面是在客户端还是服务端,并进行处理在客户端初次渲染时再次拉取数据,而不是仅限服务端。

例如:

import { firebase } from "../lib/firebase";

function HomePage(props) { return (

Home Page
) }

HomePage.getInitialProps = async ({ req }) => { // 如果在服务端,请等待数据完成加载 if (req) { // Create a reference to the cities collection const citiesRef = firebase.firestore.collection('cities'); const snapshot = await citiesRef.get(); const data = snapshot.docs.map((doc) => ({ id: doc.id, ...doc.data })); return { cities: data }; }

return { cities: [] }; };

class HomePageContainer extends React.Component { state = { cities: this.props.cities };

async componentDidMount() { // 如果在客户端,并且没有数据,请等待数据完成加载 if (!this.state.cities.length) { // Create a reference to the cities collection const citiesRef = firebase.firestore.collection('cities'); const snapshot = await citiesRef.get(); const data = snapshot.docs.map((doc) => ({ id: doc.id, ...doc.data })); this.setState({ cities: data }); } }

render() { return ; } }

export default HomePageContainer;

相关内容

热门资讯

透视透视!pokemmo手机版... 透视透视!pokemmo手机版脚本免费,impoker辅助,都是有挂(总结教程)1、pokemmo手...
透视游戏!hhpoker辅助挂... 透视游戏!hhpoker辅助挂是真的吗,智星德州辅助译码插件靠谱吗(透视)从前真的有挂(技巧教程);...
透视数据!we poker免费... 透视数据!we poker免费辅助器,xpoker辅助神器,好像真的有挂(必赢方法)we poker...
透视科技!德州私人局怎么透视,... 透视科技!德州私人局怎么透视,hhpoker透视脚本视频(透视)确实真的是有挂(必胜教程)1、下载好...
透视规律!红龙poker作弊指... 透视规律!红龙poker作弊指令,pokemmo脚本辅助器,本来有挂(靠谱教程)进入游戏-大厅左侧-...
透视透视挂!佛手大菠萝13道挂... 透视透视挂!佛手大菠萝13道挂哪里,we-poker辅助器(透视)本然有挂(新2025版)在进入佛手...
透视实锤!pokermaste... 透视实锤!pokermaster修改器,菠萝辅助器免费版的特点,切实有挂(必胜教程)菠萝辅助器免费版...
透视好友!wpk真的有透视嘛,... 透视好友!wpk真的有透视嘛,epoker透视(透视)从前是真的有挂(大神讲解)1、实时wpk真的有...
透视插件!fishpoker透... 透视插件!fishpoker透视底牌,约局吧开挂神器是真的吗,竟然真的是有挂(安装教程);1、约局吧...
透视工具!模拟器打开hhpok... 透视工具!模拟器打开hhpoker,哈糖大菠萝怎么挂(透视)往昔是有挂(教你教程);1、哈糖大菠萝怎...