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;

相关内容

热门资讯

透视开发!模拟器打开hhpok... 透视开发!模拟器打开hhpoker(透视)开挂辅助软件(原来是真的挂)-哔哩哔哩1、玩家可以在模拟器...
透视总结!wepoker祈福有... 透视总结!wepoker祈福有用吗,xpoker辅助助手,项目教程(一直真的是有挂)-哔哩哔哩1、每...
透视打法!聚星ai辅助工具收费... 透视打法!聚星ai辅助工具收费多少(透视)开挂辅助工具(本来有挂)-哔哩哔哩1、聚星ai辅助工具收费...
透视好友!佛手在线大菠萝为什么... 透视好友!佛手在线大菠萝为什么都输,德州hhpoker脚本,学习教程(真是有挂)-哔哩哔哩1、每一步...
透视辅助!德州透视是真的吗,p... 透视辅助!德州透视是真的吗,pokemmo手机版脚本,阶段教程(果然存在有挂)-哔哩哔哩透视辅助!德...
透视辅助器!aapoker辅助... 透视辅助器!aapoker辅助器是真的吗(透视)开挂辅助app(都是真的是有挂)-哔哩哔哩1、玩家可...
透视好牌!wpk透视辅助方法,... 透视好牌!wpk透视辅助方法,wepoker提高好牌率,手筋教程(果然真的是有挂)-哔哩哔哩1、we...
透视测试!pokemmo脚本辅... 透视测试!pokemmo脚本辅助器(透视)开挂辅助插件(原来是有挂)-哔哩哔哩一、pokemmo脚本...
透视黑科技!wpk私人局有透视... 透视黑科技!wpk私人局有透视吗,wepoker透视辅助下载,教材教程(其实是有挂)-哔哩哔哩wep...
透视机制!wepoker辅助器... 透视机制!wepoker辅助器安装包(透视)开挂辅助神器(本来有挂)-哔哩哔哩暗藏猫腻,小编详细说明...