将 javascript 中的变量传递给 ejs

Pass a variable from javascript to ejs

我想将在 javascript 文件中声明的变量用于 ejs 文件。

javascript:

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

var myVar = 1;

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

ejs 文件:

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

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

我也试过使用:

app.locals.myVar = 1

但是在ejs文件中没有定义。

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

在我的代码中我使用:

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

});

使用 app.locals 后:

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

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

});

虽然代码 运行 没问题,但我收到了:

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

这没有意义,因为正如我所说的代码 运行s fine.And 如果我 运行 它没有添加第二个 res.render('user_info.ejs) 我收到没有错误。

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

这是一个非常简单的示例,说明如何使用 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>
<% } %>

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

否则不行