繁体   English   中英

我可以在 _app.js 和页面中使用 getInitialProps 吗?

[英]Can I use getInitialProps in _app.js and in pages?

我正在开发我的第一个严肃的 NextJS 应用程序。 我已将其设置为为左侧导航提取 JSON 数据,而不是将它们硬编码在应用程序中的某处。 这样我就不必在每次对站点导航进行细微更改时都重新构建。

由于导航需要在每个页面上都可用,因此我将getInitialProps添加到_app.js文件中,该文件抓取左侧导航并将其传递给左侧导航组件。 但是现在当我继续构建主页时,我发现那里的getInitialProps没有运行。 似乎_app.js中的getInitialProps优先。

有没有办法两者兼得? 或者其他一些实现目标的解决方法(或者只是一种更好的方法)?

请注意,我使用getInitialProps有两个原因:

  1. getStaticProps 已出局,因为我不打算在构建时构建整个站点
  2. getServerSideProps通常不可用,因为我不喜欢它最终执行两个 http 请求:首先一个请求发送到NextJS服务器,然后服务器发送一个请求到我的 API(它恰好位于不同的服务器上)。 如果我只是获得导航之类的基本内容,则无需在NextJS服务器上运行getServerSideProps ,我宁愿跳过中间人

下面是一些简化的代码:

_app.js :

import { Provider } from "react-redux";
import axios from "axios";

import store from "../store";
import Header from "../components/Header";
import LeftNav from "../components/LeftNav";

function MyApp(props) {
    const { Component, pageProps } = props;

    return (
        <Provider store={store}>
            <Header />
            <LeftNav leftnav={props.leftnav} />
            <Component { ...pageProps } />
        </Provider>
    )
}

MyApp.getInitialProps = async (context) => {
    let config = await import("../config/config");
    let response = await axios.get(`${config.default.apiEndpoint}&cAction=getLeftNav`);

    if (response) {
        return {
            leftnav: response.data.leftNav
        };
    } else {
        return {
            leftnav: null
        };
    }
};

export default MyApp;

主页.js :

import axios from "axios";

const Home = (props) => {
    console.log("Home props", props);
    return (
        <div>home</div>
    );
};

Home.getInitialProps = async(context) => {
    
    // this only runs if the getInitialProps in _app.js is removed :(

    let config = await import("../config/config");
    let response = await axios.get( `${config.default.apiEndpoint}&cAction=getHome` );
    if ( response ) {
        return {
            home: response.data.home
        };
    } else {
        return {
            home: null
        }
    }
};
export default Home;

你必须调用App.getInitialProps(context)_app调用当前页面的getInitialProps 然后,您可以将页面的道具与来自_app的其余道具_app

import App from 'next/app'

// Remaining code...

MyApp.getInitialProps = async (context) => {
    const pageProps = await App.getInitialProps(context); // Retrieves page's `getInitialProps`
    
    let config = await import("../config/config");
    let response = await axios.get(`${config.default.apiEndpoint}&cAction=getLeftNav`);

    return {
        ...pageProps,
        leftnav: response?.data?.leftNav ?? null
    };
};

来自自定义_app文档:

当您在自定义应用程序中添加getInitialProps时,您必须import App from "next/app"getInitialProps调用App.getInitialProps(appContext)并将返回的对象合并到返回值中。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM