15

ノードに埋め込み 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);

どんな助けでも大歓迎です。

4

3 に答える 3

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);

ビューを「./views」に入れます。それを「index.ejs」と呼び、いくつかの html を入力します。

<html>
<head>
<title></title>
</head>

<body>
<p>
<%= message %>
</p>
</body>
</html>

私のために働く!

于 2011-07-30T07:08:05.070 に答える
11

応答に何かを送信する必要があります。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-01-05T05:17:51.040 に答える