【问题标题】:Nested routes in Next jsNext js中的嵌套路由
【发布时间】: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


【解决方案1】:

我终于找到了解决这个问题的方法。我根据这个建议使用布局组件的问题更改了我的代码: 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>
  )

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

【讨论】:

  • 更新(2022 年): 现在是 props.children
【解决方案2】:

下一条路线

对于这种特定情况,有一个非常好的库,可以让您定义路由,就像众所周知的 express.js 路由一样。

use it.

来自文档的示例:

const routes = require('next-routes')

                                                    // Name   Page      Pattern
module.exports = routes()                           // ----   ----      -----
.add('about')                                       // about  about     /about
.add('blog', '/blog/:slug')                         // blog   blog      /blog/:slug
.add('user', '/user/:id', 'profile')                // user   profile   /user/:id
.add('/:noname/:lang(en|es)/:wow+', 'complex')      // (none) complex   /:noname/:lang(en|es)/:wow+
.add({name: 'beta', pattern: '/v3', page: 'v3'})    // beta   v3        /v3

【讨论】:

  • 是的。我已经看过了。但我的问题是如何处理一个 SPA 嵌套路由,其中​​一个组件将加载到另一个组件而不重新加载。在 react-router 中,我们可以通过嵌套组件中的另一个 Switch 来处理这个问题。
  • 我不知道用例,你能提供一些例子吗?
  • 这个例子正是我在问题中提供的。 @Soorena
猜你喜欢
  • 1970-01-01
  • 2019-02-07
  • 2016-01-10
  • 2021-04-19
  • 2021-11-04
  • 2014-12-19
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多