Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/404.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将变量从javascript传递到ejs_Javascript_Node.js_Express_Ejs - Fatal编程技术网

将变量从javascript传递到ejs

将变量从javascript传递到ejs,javascript,node.js,express,ejs,Javascript,Node.js,Express,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访问的配置文件 我

我想使用一个在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)
   .....
ReferenceError:…用户信息。ejs:18
>>18 |高度:60px;
未定义用户
at eval(eval at(…node_modules/ejs/lib/ejs.js:464:12),:20:12)
在returnedFn(…node_modules/ejs/lib/ejs.js:493:17)
在View.exports.renderFile[作为引擎](…/node_modules/ejs/lib/ejs.js:350:31)
.....
这没有什么意义,因为正如我所说,代码运行得很好。如果我运行它时没有添加第二个
res.render('user\u 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.js
var express=需要(“express”);
var-app=express();
var server=app.listen(3000);
app.locals.myVar=1;
app.get('/',函数(req,res){
res.render('index.ejs');
});
//视图/index.ejs
myVar来了!
嘘,没有我的车!

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 %>

否则它将无法工作。

app.locals.myVar
应该可以工作,前提是您将其设置在正确的位置并在模板中正确使用。您可能应该发布更多代码。JS不会在文件之间“传递”变量。相反,所有文件都在全局上下文中加载和运行(在浏览器中是窗口)。@HiteshKumar您将如何从服务器端将其添加到
窗口
对象?EJS模板不是这样工作的。在node中,不是window,而是一个名为“global”的变量,但与在客户端不向“window”对象追加数据的方式大致相同,您不应该向“global”对象追加数据对象在服务器端。@George在下面发布了一个可持续的解决方案-没有全局变量。:Hmm..如果我还有
res.render('index',{user:req.user,message:[]),我可以问你吗如何正确编写'index.ejs'?我的意思是,我正在尝试:
app.get('/',function(req,res){res.render('index',{user:req.user,message:[]});res.render('index.ejs');}
但它在index.ejs中给了我一些奇怪的引用错误,尽管它可以正常工作。:很抱歉坚持..用几句话来说,我在
app.get('/')
中有2个
res.render
语句。尽管它可以工作,但它给了我上面的引用错误。你能告诉我这是否可能吗?谢谢..@George可能为此提出一个新问题?或者错误与您之前得到的相同?如果是这样的话,你能把原来问题的错误加进去吗?@George first:调用
res.render()
两次都不行。其次,我将猜测没有定义
req.user
,这将使模板中的
user
变量未定义。这将指向你的应用程序中与身份验证相关的问题,而不是太多的模板。但是,如果我在没有
res.render('user_info.ejs')
的情况下运行它,我绝对不会收到关于
req.user
的错误。有没有一种方法可以使用
app.locals.myVar
而不将其放入render?
app.set('view engine', 'ejs');