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;

相关内容

热门资讯

黑科技辅助挂!(WPk)总是真... 黑科技辅助挂!(WPk)总是真的是有挂,(WPK)一直真的有挂,德州论坛(有挂系统);黑科技辅助挂!...
黑科技辅助挂!云扑克德州辅助工... 黑科技辅助挂!云扑克德州辅助工具,(wepower德州)一贯是真的有挂,wepoke教程(有挂工具)...
黑科技辅助挂!aaPOKER透... 黑科技辅助挂!aaPOKER透明挂下载,(AAPoker)一直存在有挂,系统教程(有挂教程);1、该...
黑科技辅助挂!wEpOke软件... 黑科技辅助挂!wEpOke软件透明挂,wepOke透明挂黑科技设备,黑科技教程(有挂插件);1、构建...
黑科技辅助挂!(WpK)其实是... 黑科技辅助挂!(WpK)其实是真的有挂,(wpK)原来是真的有挂,德州教程(有挂总结)1)德州辅助挂...
黑科技辅助挂!智星菠萝德州辅助... 黑科技辅助挂!智星菠萝德州辅助器工具,(智星德州菠萝)切实真的是有挂,德州论坛(有挂科技)1、下载好...
黑科技辅助挂!AAPOKEr透... 黑科技辅助挂!AAPOKEr透明挂系统机制,(aapokER)详细辅助存在挂教程(有挂透视)1、AA...
黑科技辅助挂!智星德州菠萝辅助... 黑科技辅助挂!智星德州菠萝辅助器工具,智星德州外挂,2025新版(有挂辅助器);1、智星德州菠萝系统...
黑科技辅助挂!aapOKER透... 黑科技辅助挂!aapOKER透明挂有外挂,(AAPOker)切实真的有挂,透明挂教程(有挂软件);1...
黑科技辅助挂!(AAPOKEr... 黑科技辅助挂!(AAPOKEr)一贯是真的有挂,(aa扑克)果然真的有挂,攻略教程(有挂透明)1、上...