将变量从javascript传递给ejs

时间:2016-06-03 14:14:19

标签: javascript node.js express ejs

我想使用在javascript文件中声明的变量到ejs文件。

的javascript:

var myVar = 1;
if ( my Var ) ....

在ejs文件中,我想在几个if语句中使用该变量,我必须再次声明它才能使用它。

ejs文件:

app.locals.myVar = 1

我怎样才能避免这种情况?或者有没有办法创建一个可以从javascript和ejs访问的配置文件?

我也尝试使用:

app.get('/', function (req, res) { res.render('index', { user : req.user, message: [] }); });

但在ejs文件中未定义。

-------更新--------------------------

在我使用的代码中:

app.get('/', function (req, res) {

   res.render('index', { user : req.user, message: [] });
   res.render('user_info.ejs');

使用app.locals后:

ReferenceError: ....user_info.ejs:18

 >> 18|            height:60px;


user is not defined
    at eval (eval at <anonymous> (...node_modules/ejs/lib/ejs.js:464:12), <anonymous>:20:12)

    at returnedFn (...node_modules/ejs/lib/ejs.js:493:17)
    at View.exports.renderFile [as engine] (.../node_modules/ejs/lib/ejs.js:350:31)
   .....

});

即使代码运行正常,我也收到了:

res.render('user_info.ejs)

这并没有结果,因为我说代码运行正常。如果我在没有添加第二个for (uint8_t i=0; i<6; i++) { readbuffer[i] = Wire.read(); } 的情况下运行它,我没有收到任何错误。

那么,我可以有两个res.render语句吗?

2 个答案:

答案 0 :(得分:8)

app.locals.myVar方法应该有用,所以必须要阻碍某些方法。但您可以完全避免使用app.locals.myVar变量直接传递给您的视图:

var express = require('express');
var app = express();

app.get('/', function(req, res) {
    var myVar = 1;
    res.render('testPage', { myVar : myVar });
});

myVar变量现在应该可用于“testPage”ejs文件。你可以在里面做:

<%= myVar %>

看到输出“1”。

最后,请确保已将视图引擎设置为ejs:

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

否则它将无效。

答案 1 :(得分:4)

这是一个非常简单的示例,说明app.locals如何用于将变量公开给(EJS)模板:

// app.js
var express = require('express');
var app     = express();
var server  = app.listen(3000);

app.locals.myVar = 1;

app.get('/', function(req, res) {
  res.render('index.ejs');
});

// views/index.ejs
<% if (myVar) { %>
  <h1>myVar is here!</h1>
<% } else { %>
  <h1>Boohiss no myVar!</h1>
<% } %>