我正在尝试将 Express Router 与 Next.js 结合使用定制快递服务器示例 https://github.com/zeit/next.js/blob/master/examples/custom-server-express/server.js作为我的样板。唯一的区别是我试图在 paths/router.js 上外部定义路由,如下所示:
server.js 中的代码:
const express = require('express')
const next = require('next')
const port = parseInt(process.env.PORT, 10) || 3000
const dev = process.env.NODE_ENV !== 'production'
const app = next({ dev })
const handle = app.getRequestHandler()
const routes = require('./routes/router')
app.prepare()
.then(() => {
const server = express()
server.use('/', routes)
server.get('*', (req, res) => {
return handle(req, res)
})
server.listen(port, (err) => {
if (err) throw err
console.log(`> Ready on http://localhost:${port}`)
})
})
module.exports = app;
代码在routes/router.js中:
const express = require('express'),
app = require('../server.js'),
router = express.Router();
router.get('/a', (req, res) => {
return app.render(req, res, '/b', req.query)
})
router.get('/b', (req, res) => {
return app.render(req, res, '/a', req.query)
})
router.get('/posts/:id', (req, res) => {
return app.render(req, res, '/posts', { id: req.params.id })
})
module.exports = router;
此时,即使我从 server.js 导入“app”,app 在 router.js 中也不可用。
我的逻辑不正确吗?
如果不是,那么为什么应用程序在 router.js 中不可用?