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

Kun*_*Rai 6 javascript reactjs next.js

我已从 getStaticProps 返回 json 响应,控制台将其记录在 getStaticProps 中以验证正确的 json 响应。所以,fetch 工作正常,我从 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;

Run Code Online (Sandbox Code Playgroud)

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

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

Clo*_*ery 8

问题出在您的自定义应用程序文件中,如果您删除自定义应用程序包装器,您的问题将会解决,但如果您想保留自定义应用程序包装器,只需像_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;
Run Code Online (Sandbox Code Playgroud)

欲了解更多信息,请查看此处:自定义应用程序 - NextJS