我正在关注Steven Senderson关于NodeJS的帖子。我已按照此question中的建议更新了Express中的版本更改代码。现在,当我使用index.html
访问我的localhost:13253
页面时,它会按原样呈现index.html
的内容。它不是使用layout.html
渲染它。我已经从ejs.js
和ejs-middleware
跟踪了它,但是函数被调用但是没有应用布局。服务器代码如下:
var express = require('express'),
app = express(),
api = require("./api/server.js"),
ejsm = require('ejs'),
ejsMiddleware = require('ejs-middleware');
app.use('/api', api);
app.use(ejsMiddleware(__dirname + '/Static', 'html', app));
app.use(express.static(__dirname + '/Static'));
app.listen(process.env.port || 12345);
编辑: -
//INDEX.HTML
this is homepage
//layout.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>Inventify (alpha)</title>
<script type="text/jscript" src="/scripts/jquery-1.8.3.min.js"></script>
<script type="text/javascript" src="/scripts/knockout-2.2.0.js"></script>
<link rel="stylesheet" href="/Styles/app.css"/>
</head>
<body>
<h1 class="site-title">
<a href="/">Iventify<span class="version">(alpha)</span></a>
</h1>
<div class="main-container">
<%- body %>
</div>
</body>
<script type="text/javascript">
alert('from template');
</script>
</html>
答案 0 :(得分:0)
运行express二进制文件以生成裸露的快速项目(它执行此操作!),
./node_modules/express/bin/express
以及
部分app.set('view_engine', 'jade');
将其更改为ejs。现在,它将使用.ejs
作为ejs模板读取所有文件。