【发布时间】:2019-02-05 21:51:13
【问题描述】:
我有一个简单的 SPA,App 和 About 组件如下所示。 当我点击关于链接时,关于页面出现在链接下方。 问题是当我点击“关于我”链接时,加载的是“我”页面而不是关于页面。我真正想要的是在 nextjs 中有嵌套路由。似乎一级路由正在加载。但我不知道如何将它添加到我的子组件中。
import App, { Container } from 'next/app'
import React from 'react'
import Link from 'next/link'
class MyApp extends App {
static async getInitialProps({ Component, router, ctx }) {
let pageProps = {}
if (Component.getInitialProps) {
pageProps = await Component.getInitialProps(ctx)
}
return { pageProps }
}
render() {
const { Component, pageProps } = this.props
return <Container>
<ul>
<li><Link href="/news">News</Link></li>
<li><Link href="/about">About</Link></li>
</ul>
<Component{...this.props} />
</Container>
}
}
export default MyApp
import React from 'react'
import Link from 'next/link'
import Router from 'next/router'
class About extends React.Component {
render() {
return (
<div id="main">
<li><Link href="/about/company">About company</Link></li>
<li><Link href="/about/me">About me</Link></li>
</div>
)
}
}
export default About
【问题讨论】:
-
您使用的是自定义服务器吗?你还有
useFileSystemPublicRoutes选项吗? -
@kyle 不。我使用 create-next-app 创建了项目。我认为 useFileSystemPublicRoutes 已打开,因为我没有对默认配置进行任何更改。
标签: reactjs server-side-rendering next.js