我确定这很愚蠢,但是我不能让它为我的生活工作,我只想在ejs上用if做一个简单的for语句,但它会在express中返回一个意外的catch事件。 / p>
设置场景,我有一个JSON,它在nodejs中使用ejs作为我的模板渲染器设置一个注册表单,假设我有以下代码:
var userData:{
"username":"User name",
"email":"johndoe@gmail.com",
"password":"Please enter Password",
"birthdate":"date"
}
我有一个ejs文件
<h1 id="page-title"><%= title %></h1>
<div id="list">
<form action="user/create/" method="post" accept-charset="utf-8">
<div class="item-new">
<% for (var key in userData){ %>
<% if(key != 'birthdate'){ %>
<input class="input" type="text" name="<%= key %>" placeholder="<%= userData[key] %>"/>
<% }else{ %>
//do something
<% } %>
</div>
我试图事先定义变量并检查定义的值
答案 0 :(得分:1)
如果您提供的示例确实是您的所有代码,那么您并未关闭所有代码,具体而言,您并未关闭for循环,div或其表单。当我关闭所有这些时,视图将为我呈现没有错误。这是我使用的ejs:
<!DOCTYPE html>
<html>
<head>
<title><%= title %></title>
<link rel='stylesheet' href='/stylesheets/style-min.css' />
</head>
<body>
<h1 id="page-title"><%= title %></h1>
<div id="list">
<form action="user/create/" method="post" accept-charset="utf-8">
<div class="item-new">
<% for (var key in userData){ %>
<% if(key != 'birthdate'){ %>
<input class="input" type="text" name="<%= key %>" placeholder="<%= userData[key] %>"/>
<% } else{ %>
<% } %>
<% } %>
</div>
</form>
</div>
</body>
</html>
我用这个函数渲染它:
exports.test = function(req, res){
res.render('test', { title: 'nodejs + ejs for if express returns a unexpected catch', userData:{
"username":"User name",
"email":"johndoe@gmail.com",
"password":"Please enter Password",
"birthdate":"date"
}});
};
当我使用上面的内容时,我得到了这个结果: