nodejs + ejs for if express返回一个意外的catch

时间:2013-07-01 19:29:17

标签: node.js backbone.js ejs

我确定这很愚蠢,但是我不能让它为我的生活工作,我只想在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>

我试图事先定义变量并检查定义的值

1 个答案:

答案 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"
        }});
};

当我使用上面的内容时,我得到了这个结果: enter image description here