题
我想使用嵌入的JavaScript渲染节点。我用它NPM,这里给出的安装: https://github.com/visionmedia/ejs
和我有以下的代码,但它似乎没有工作时:
var connect = require('connect'),
ejs = require('ejs');
var server = connect.createServer(
connect.bodyDecoder(),
connect.methodOverride(),
connect.staticProvider(__dirname + '/public'),
function(req,res) {
ejs.render('hi');
}
);
server.listen(9000);
任何帮助不胜感激。
解决方案
您需要发送的东西的反应。从连接你好世界
var connect = require('../../lib/connect');
var server = connect.createServer(function(req, res){
var body = 'Hello World';
res.writeHead(200, {
'Content-Type': 'text/plain'
, 'Content-Length': body.length
});
res.end(body);
});
server.listen(3000);
console.log('Connect server listening on port 3000');
因此,对于你的应用程序,你会想取代:
function(req,res) {
ejs.render('hi');
}
使用类似:
function(req,res) {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end(ejs.render('hi'));
}
运作的?
其他提示
尝试:(假定已安装了快速和EJS模块)
var express = require('express');
var app = express.createServer();
app.configure(function() {
app.use(express.bodyParser());
app.use(express.static('./static/'));
app.use(app.router);
});
app.set('view engine', 'ejs');
app.set('view options', {
layout: false
});
app.get('/', function(req, res) {
res.render('index', {
message : 'De groeten'
});
});
app.listen(3000);
和放入” ./views'的图。称之为“index.ejs”,并与一些HTML填充它:
<html>
<head>
<title></title>
</head>
<body>
<p>
<%= message %>
</p>
</body>
</html>
对我的作品!
设置您的视图引擎使用EJS。
app.set("view engine", "ejs");
现在设置根路径,这样当你从浏览器访问您的服务器,请参阅下面将会加载的东西。
var app = express();
// ROOT ROUTE
app.get("/", function(req, res) {
res.render("landingpage"); // use to render an ejs template page
res.send("hello world"); // to render an empty page with the hello world message
});
不隶属于 StackOverflow