我正在尝试将Embedded 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);
Run Code Online (Sandbox Code Playgroud)
任何帮助非常感谢.
Elm*_*mer 12
试试这个:(假设你已经安装了express和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);
Run Code Online (Sandbox Code Playgroud)
并在'./views'中放置一个视图.称之为'index.ejs'并用一些html填充它:
<html>
<head>
<title></title>
</head>
<body>
<p>
<%= message %>
</p>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
适合我!
Ran*_*Etc 11
您需要向响应发送一些内容.从连接hello-world
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');
Run Code Online (Sandbox Code Playgroud)
因此,对于您的应用,您需要替换:
function(req,res) {
ejs.render('hi');
}
Run Code Online (Sandbox Code Playgroud)
有类似的东西:
function(req,res) {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end(ejs.render('hi'));
}
Run Code Online (Sandbox Code Playgroud)
那样有用吗?
| 归档时间: |
|
| 查看次数: |
33772 次 |
| 最近记录: |