ejs中的if语句

If statement in ejs

实际上,我的 layout.ejs 代码如下所示:

    <!-- begin:: Page -->
      <div class="m-page">
        <%- partial('./partials/topnav.ejs') %>
        <!-- begin::Body -->
        <div class="m-body">
          <%- partial('./partials/leftnav.ejs') %>
          <div class="m-wrapper">
            <%- body %>
          </div>
        </div>
        <!-- end:: Body -->
        <%- partial('./partials/footer.ejs') %>
      </div>
      <!-- end:: Page -->
      <%- partial('./partials/side.ejs') %>

我想在导航栏和正文中使用不同的控制器,所以我这样划分了视图。

现在我希望登录页面有所不同(根本没有导航栏)。我试图用 ng-show 隐藏导航栏,但它闪烁,我试图停止闪烁,但我仍然看到左边的栏几秒钟,这真的很麻烦。

所以如果页面的位置是/login,我想尝试只显示正文。我不能为此使用控制器,因为已经用于导航栏和正文部分的控制器会发生冲突。

我想使用这样的东西:

<script type="text/javascript">
  var path = this.window.location.pathname;
</script>

...


<% if (path == '/login') { %>
  <%- body %>
<% } else{ %>
  ..the previous code..
<% } %>

但这会出现 "path is not defined" 错误。 所以我四处寻找有关 EJS if 语句的信息,但充其量它总是属于 else 条件。

您需要定义一个 path 变量来保存您需要的正确值。

因此在您相应的控制器中创建它并将其传递给您的视图,如下所示:

res.view(pathToYourView, {  path: yourPath, ... });