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...
外挂模块!newpoker脚本... 外挂模块!newpoker脚本,xpoker辅助器-原来一直总是有辅助教程(哔哩哔哩)xpoker辅...
外挂指引!德普之星透视辅助软件... 外挂指引!德普之星透视辅助软件下载,智星菠萝有挂吗-本来一直总是有辅助工具(哔哩哔哩)1、用户打开应...
外挂攻略!拱趴大菠萝机器人,德... 外挂攻略!拱趴大菠萝机器人,德州圈脚本-切实真的是有辅助脚本(哔哩哔哩)拱趴大菠萝机器人破解侠是真的...
外挂手段!哈糖大菠萝怎么挂,德... 外挂手段!哈糖大菠萝怎么挂,德州局透视-总是真的是有辅助脚本(哔哩哔哩)1、起透看视 哈糖大菠萝怎么...
外挂指南书!impoker辅助... 外挂指南书!impoker辅助,sohoo开挂辅助-原来真的有辅助教程(哔哩哔哩)1、sohoo开挂...
外挂办法!约局吧作必弊脚本,a... 外挂办法!约局吧作必弊脚本,agpoker辅助-一直真的有辅助神器(哔哩哔哩)1、约局吧作必弊脚本辅...
外挂指南!线上德州的辅助器是什... 外挂指南!线上德州的辅助器是什么,佛手大菠萝13道挂哪里-确实是真的有辅助工具(哔哩哔哩)1、上手简...
外挂法子!德普之星的辅助工具介... 外挂法子!德普之星的辅助工具介绍,德普之星透视-切实存在有辅助方法(哔哩哔哩)1、打开软件启动之后找...
外挂烘培!newpoker怎么... 外挂烘培!newpoker怎么安装脚本,sohoopoker辅助-确实真的是有辅助插件(哔哩哔哩)1...