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;

相关内容

热门资讯

约局吧开挂神器是真的吗!来玩德... 约局吧开挂神器是真的吗!来玩德州破解器(透视)软件-其实分享真的有挂1、约局吧开挂神器是真的吗公共底...
hhpoker德州透视!wep... hhpoker德州透视!wepoker怎么设置盖牌(透视)攻略-总是有挂是有挂wepoker怎么设置...
wepoker辅助器激活码!i... wepoker辅助器激活码!impoker辅助(透视)神器-好像科普是真的挂1、完成wepoker辅...
如何判断wpk辅助软件的真假!... 如何判断wpk辅助软件的真假!WePoKer辅助器(透视)教程-果然普及真的是有挂进入游戏-大厅左侧...
we-poker辅助软件教程!... we-poker辅助软件教程!德扑HHpoker有挂吗(透视)挂-竟然专业真的有挂1、we-poke...
德扑之心免费透视!pokemm... 德扑之心免费透视!pokemmo手机辅助软件(透视)技巧-都是解密真的是有挂1、完成pokemmo手...
佛手在线大菠萝为什么都输!we... 您好,佛手在线大菠萝为什么都输这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302...
wepoker有辅助工具吗!h... wepoker有辅助工具吗!hhpoker德州挂真的有吗(透视)脚本-切实揭幕是真的挂1、让任何用户...
wepoker有没有机器人!h... wepoker有没有机器人!hh poker软件(透视)教程-好像普及真的是有挂1、完成wepoke...
wepoker轻量版有透视吗!... wepoker轻量版有透视吗!aapoker怎么拿好牌(透视)插件-切实普及是有挂1、进入到wepo...