[英]Can I use getInitialProps in _app.js and in pages?
我正在开发我的第一个严肃的 NextJS 应用程序。 我已将其设置为为左侧导航提取 JSON 数据,而不是将它们硬编码在应用程序中的某处。 这样我就不必在每次对站点导航进行细微更改时都重新构建。
由于导航需要在每个页面上都可用,因此我将getInitialProps
添加到_app.js
文件中,该文件抓取左侧导航并将其传递给左侧导航组件。 但是现在当我继续构建主页时,我发现那里的getInitialProps
没有运行。 似乎_app.js
中的getInitialProps
优先。
有没有办法两者兼得? 或者其他一些实现目标的解决方法(或者只是一种更好的方法)?
请注意,我使用getInitialProps
有两个原因:
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.