我想使用在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语句吗?
答案 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>
<% } %>