我正在尝试使用节点的嵌入式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);非常感谢您的帮助。
发布于 2011-01-05 13:17:51
您需要向响应发送一些内容。从connect 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');因此,对于您的应用程序,您需要替换:
function(req,res) {
 ejs.render('hi');
}使用类似这样的东西:
function(req,res) {
  res.writeHead(200, { 'Content-Type': 'text/plain' });
  res.end(ejs.render('hi'));
}这行得通吗?
发布于 2011-07-30 15:08:05
试试这个:(假设你已经安装了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);并在“./views”中放置一个视图。将其命名为'index.ejs‘,并填充一些html:
<html>
<head>
<title></title>
</head>
<body>
<p>
<%= message %>
</p>
</body>
</html>对我很管用!
发布于 2017-08-02 01:36:09
将视图引擎设置为使用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
});https://stackoverflow.com/questions/4600952
复制相似问题