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、任何凑一桌...
第十分钟模板!最悠闲的辅助,火... 第十分钟模板!最悠闲的辅助,火神辅助官网地址(辅助)竟然是真的下载(哔哩哔哩)1.火神辅助官网地址 ...
五分钟妙招!阿拉斗牌辅助,新鸿... 五分钟妙招!阿拉斗牌辅助,新鸿狐脚本(辅助)本来真的有神器(哔哩哔哩)1、每一步都需要思考,不同水平...
第4分钟举措!新广西老友辅助,... 第4分钟举措!新广西老友辅助,财神十三章安装包(辅助)好像真的有软件(哔哩哔哩)1、进入到财神十三章...
第7分钟方式!蜜瓜大厅辅助免费... 第7分钟方式!蜜瓜大厅辅助免费下载,新西部辅助器(辅助)竟然真的是有软件(哔哩哔哩)1)蜜瓜大厅辅助...
第三分钟指南!蛮王大厅辅助教程... 第三分钟指南!蛮王大厅辅助教程,新道游房卡辅助器(辅助)原来存在有神器(哔哩哔哩)蛮王大厅辅助教程透...
两分钟法子!财神破解版全自动脚... 两分钟法子!财神破解版全自动脚本,财神十三章安装包(辅助)一贯是有平台(哔哩哔哩)暗藏猫腻,小编详细...
1分钟办法!龙江填大坑视频攻略... 1分钟办法!龙江填大坑视频攻略,火神辅助官网地址(辅助)好像真的有神器(哔哩哔哩)1、金币登录送、破...
第八分钟举措!南宁老友麻将免费... 第八分钟举措!南宁老友麻将免费辅助器,樱花之盛辅助真的假的(辅助)好像是有修改器(哔哩哔哩);1、让...
6分钟积累!潘潘讲故事有外g挂... 6分钟积累!潘潘讲故事有外g挂吗,新九游辅助软件(辅助)确实真的是有app(哔哩哔哩)1、潘潘讲故事...