Next js中的嵌套路由
Nested routes in Next js
我有一个简单的 SPA,App 和 About 组件如下所示。
当我单击关于 link 时,关于页面出现在 link 下。
问题是,当我单击 "About me" link 时,会加载 "me" 页面而不是关于页面。我真正想要的是在 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
下一步路线
有一个非常适合这种特定情况的库,可以让您像众所周知的 express.js
路线一样定义路线。
来自文档的示例:
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
我终于找到了解决这个问题的方法。我根据这个建议使用布局组件的问题更改了我的代码:
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>
)
这可以防止重新加载页面。但是,它仍然会重新呈现整个页面。
我有一个简单的 SPA,App 和 About 组件如下所示。 当我单击关于 link 时,关于页面出现在 link 下。 问题是,当我单击 "About me" link 时,会加载 "me" 页面而不是关于页面。我真正想要的是在 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
下一步路线
有一个非常适合这种特定情况的库,可以让您像众所周知的 express.js
路线一样定义路线。
来自文档的示例:
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
我终于找到了解决这个问题的方法。我根据这个建议使用布局组件的问题更改了我的代码: 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>
)
这可以防止重新加载页面。但是,它仍然会重新呈现整个页面。