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, ... });
实际上,我的 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, ... });