gpt4 book ai didi

reactjs - Next js 中的嵌套路由

转载 作者:行者123 更新时间:2023-12-03 13:37:41 28 4
gpt4 key购买 nike

我有一个简单的 SPA,应用程序和关于组件如下所示。当我单击“关于”链接时,“关于”页面会出现在链接下方。问题是,当我单击“关于我”链接时,会加载“我”页面而不是关于页面。我真正想要的是在 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

最佳答案

我终于找到了解决这个问题的方法。我根据建议使用布局组件的问题更改了我的代码: https://github.com/zeit/next.js/issues/4166

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>
{this.props.child}
</div>

)
}
}
export default About

那我小时候要表现的应该是这样的:

const me = () => (
<About>
<div>
About me
</div>
</About>
)

这可以防止页面重新加载。但是,它仍然重新呈现整个页面。

关于reactjs - Next js 中的嵌套路由,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52105699/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com