首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >app.get不是express.js中的函数

app.get不是express.js中的函数
EN

Stack Overflow用户
提问于 2018-07-05 02:06:55
回答 3查看 4.5K关注 0票数 0

我实际上不能弄清楚为什么在下面的代码片段中的index.js文件中抛出一个错误: app.get不是一个函数。请帮帮我..

//这是我的app.js文件

代码语言:javascript
复制
const express = require('express');
const app = express();
const helpers = require('./helpers');
const routes = require('./index')

app.use((req, res, next) => {
    app.locals.h = helpers;
    next();
});

app.use('/', routes);

app.set('views',(__dirname));
app.set('view engine', 'pug');

app.listen(3000,()=>console.log('port 3000'));

module.exports = app;

//这是我的index.js文件

代码语言:javascript
复制
const app = require('./app')

app.get('/',(req,res) => {
   res.render('template');
})

module.exports = router;

//helpers.js

代码语言:javascript
复制
exports.title = "NODEjs";

//template.pug

代码语言:javascript
复制
doctype html
html
  head
    title=`${h.title}`
  body
    h1 myHeading #{h.title}
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-07-05 02:10:34

您有一个循环依赖循环,而不是创建无限循环,require()子系统会检测到这一点并无法加载您的模块。

app.js中,您可以加载index.js。在index.js中,您可以加载app.js。循环依赖循环。

有两种不同的技术可以用来解决您的特定问题。你似乎在使用一些技术和另一些技术,这就产生了你的问题。

在单独的文件中定义新路由的经典方法是只创建该文件并导出自己的路由器。然后,它将路由分配给路由器(而不是app),因此其他文件根本不需要app对象。因为您展示了module.exports = router,所以看起来您掌握了该技术的一部分,但只是其中的一部分。

下面是代码是如何以这种方式工作的:

代码语言:javascript
复制
// app.js
const express = require('express');
const app = express();
const helpers = require('./helpers');

app.use((req, res, next) => {
    app.locals.h = helpers;
    next();
});

// hook in routes from the index.js router
app.use('/', require('./index'));

app.set('views',(__dirname));
app.set('view engine', 'pug');

app.listen(3000,()=>console.log('port 3000'));


// index.js
const router = require('express').Router();
router.get('/',(req,res) => {
    res.render('template');
});

module.exports = router;

您也可以在加载时将app传递给index.js,而不是让它尝试导入app。这也解决了循环依赖问题。

代码语言:javascript
复制
const express = require('express');
const app = express();
const helpers = require('./helpers');

// pass app here so it can register routes
require('./index')(app);

app.use((req, res, next) => {
    app.locals.h = helpers;
    next();
});

app.use('/', routes);

app.set('views',(__dirname));
app.set('view engine', 'pug');

app.listen(3000,()=>console.log('port 3000'));

更改index.js以导出您调用的模块构造函数,并将app传递给:

代码语言:javascript
复制
module.exports = function(app) {
    app.get('/',(req,res) => {
        res.render('template');
    })
}
票数 2
EN

Stack Overflow用户

发布于 2018-11-29 02:08:25

在第一行添加括号:

代码语言:javascript
复制
const express = require('express')();
票数 0
EN

Stack Overflow用户

发布于 2019-12-10 02:03:31

第一个答案应该被接受。这只是由于本例中的循环依赖关系而发生的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51179031

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档