从getStaticProps返回的组件中获取未定义的props

库纳尔·赖(Kunal Rai)

我从getStaticProps返回了json响应,并且控制台将其记录在getStaticProps中,以验证正确的json响应。因此,提取工作正常,我从API得到正确的响应。

import Layout from '../components/layout';
import fetch from 'isomorphic-unfetch';
const Index = ({data}) => {
    console.log(data)
    return (
        <Layout>
            <div>
                <h1>Welcome to Next Application</h1>
                <h3>Users List</h3>
                {data ? 
                data.map((item, i) => {
                   return (
                   <li key={i}>{item.name}</li>
                   )
               }):
                <span>Loading...</span>
               }
                   
               
            </div>
        </Layout>
    );
}
export const getStaticProps = async () => {
    const response = await fetch(`https://jsonplaceholder.typicode.com/users`);
    const data = await response.json();
    console.log(data);
    return {
        props:{
            data
        } 
    }
}
export default Index;

获取索引组件中未定义的数据。我想念什么?

我的输出-https : //ibb.co/Ns9143C Github- https://github.com/ho-dor/next-poc

问题出在您的自定义应用程序文件中,如果您删除了自定义应用程序包装程序,您的问题将得到解决,但是如果您要保留自定义应用程序包装程序,请_app.js像这样更新您的文件

import App from 'next/app';

const MyApp = ({ Component, props }) => {
    return (
        <div className="MyApp">
            <p>_app.js file</p>
            <Component {...props} />
        </div>
    );
};

MyApp.getInitialProps = async (appContext) => {
    // calls page's `getInitialProps` and fills `appProps.pageProps`
    const appProps = await App.getInitialProps(appContext);

    return { ...appProps };
};

export default App;

有关更多信息,请单击此处:定制应用程序-NextJS

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章