0

我确定这很愚蠢,但我无法让它为我的生活工作,我只想在 ejs 上使用 if 内部做一个简单的 for 语句,但它一直在 express 中返回一个意外的 catch 事件。

为了设置场景,我有一个 JSON,它使用 ejs 作为我的模板渲染器在 nodejs 中设置一个注册表单,假设我有以下代码:

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>

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

4

1 回答 1

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

当我使用上述内容时,我得到了这个结果: 在此处输入图像描述

于 2013-07-02T02:09:09.480 回答