【发布时间】:2017-05-14 23:51:57
【问题描述】:
当我尝试在 app.js 文件中调用路由时,我的应用程序没有加载“EJS”模块,我想知道原因。
我的问题是 similar in scope to this one,但它有一些额外的皱纹,没有在答案中解决,所以我想我会完全把它变成一个新问题。
如果我像这样启动一个非常基本的app.js 文件并调用ejs,它会按预期工作并且不会引发错误。
APP.JS:
var express = require('express');
var app = express();
app.set('view engine', 'ejs');
app.get('/', function(req, res){
res.send("Hello World");
}).listen(3000, function(){
console.log("The port is now listening at 3000");
});
但是,一旦我修改 app.js 以使用路由来呈现视图,我就会在标题中收到错误消息。
以下脚本提供了错误:
APP.JS:
var express = require('express');
var app = express();
var root = require('./routes/index');
app.set('view engine', 'ejs');
app.set('views', __dirname + '/views');
app.use(express.static(__dirname + '/public'));
app.use(root);
app.listen(3000, function(){
console.log("The port is now listening at 3000");
});
module.exports = app;
我用来建立路由的 index.js 文件如下所示:
INDEX.JS:
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/', function(req, res) {
res.render('index', {
pageTitle: 'The Formula Generator',
pageDescription: 'Easily manage and store your supplement formulas',
pageID: 'home' });
});
module.exports = router;
EJS 已正确加载到我的 package.json 中,如下所示:
PACKAGE.JSON:
"dependencies": {
"body-parser": "~1.15.2",
"cookie-parser": "~1.4.3",
"debug": "~2.2.0",
"ejs": "^2.5.5",
"express": "~4.14.0",
"mongodb": "^2.2.16",
"monk": "^3.1.3",
"morgan": "~1.7.0",
"serve-favicon": "~2.3.0"
},
它也安装在我的 node_modules 文件夹中。
我的文件结构目前如下所示:
【问题讨论】:
标签: node.js express package.json