Node.js - EJS 示例

发布于 2024-10-10 09:03:04 字数 505 浏览 10 评论 0原文

我正在尝试使用嵌入式 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);

非常感谢任何帮助。

I am trying to use Embedded Javascript renderer for node. I installed it using npm, as given here: https://github.com/visionmedia/ejs

And I have the following code, but it does not seem to work:

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

Any help greatly appreciated.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

眼角的笑意。 2024-10-17 09:03:04

试试这个:(假设您安装了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>

对我有用!

try this: (assuming you have the express and ejs modules installed)

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

and put a view in './views'. call it 'index.ejs' and fill it with some html:

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

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

works for me!

盗心人 2024-10-17 09:03:04

您需要向响应发送一些内容。从 连接 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'));
}

这有效吗?

You need to send something to the response. From the 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');

So for your app you'll want to replace:

function(req,res) {
 ejs.render('hi');
}

With something like:

function(req,res) {
  res.writeHead(200, { 'Content-Type': 'text/plain' });
  res.end(ejs.render('hi'));
}

Does that work?

月光色 2024-10-17 09:03:04

将您的视图引擎设置为使用 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
});

Set your view engine to use ejs.

app.set("view engine", "ejs");

Now set up the root route so that it will load something when you access your server from a browser, see below.

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
});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文