我来自PHP,其中声明和使用用户定义的函数比JSP(我认为)非常容易。为了更轻松地完成任务,我使用PHP函数(在* .php文件中)将HTML模板分成几个部分,并在需要时调用它们,如下所示:
require_once 'resource.php';
load_header($title);
load_navbar($title);
<!--Other content goes here-->
load_footer();
在 resource.php 中,以上所有函数都包含所需的代码。
现在在JSP中,我想做同样的事情。所以我在JSP中编写一个函数,如下所示:
<%
int login = 0;
if( session.getAttribute("username") != null ) {
login = 1;
} else {
login = 0;
}
%>
<%!
public static void load_navbar(String title) {
%>
<nav class="navbar navbar-inverse navbar-static-top">
<div class="container-fluid">
<!-- Brand and toggle get grouped for better mobile display -->
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="#">Brand</a>
</div>
<!-- Collect the nav links, forms, and other content for toggling -->
<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
<ul class="nav navbar-nav navbar-left">
<li class="active left-margin"><a href="#"> <i class='fa fa-fw fa-home'></i> Home</a> </li>
</ul>
<ul class="nav navbar-nav navbar-right">
<%
if( login == 0 ) {
%>
<li><a href="#">Login</a></li>
<%
} else if( login == 1 ) {
%>
<li><a href="#">Logout</a></li>
<%
}
%>
</ul>
</div><!-- /.navbar-collapse -->
</div><!-- /.container-fluid -->
</nav>
<%!
}
%>
要在我的目标页面中包含该文件,我将编写以下代码行:
<jsp:include page="include/navbar.jsp"></jsp:include>
但问题是, load_navbar()功能中的所有代码都会自动添加到我的页面中而不调用该函数。我想在调用函数时加载这些代码。即:
<body>
<%! load_navbar("Title goes here"); %>
</body>
任何人都可以帮我解决问题 感谢
答案 0 :(得分:1)
jsp:include将发出包含/ navbar.jsp的请求,并使用jsp:include将响应附加到JSP。对于您的情况,您希望使用&lt;%@ include file =“include / navbar.jsp”%&gt;。在这种情况下,navbar.jsp的内容将在转换阶段使用include伪指令添加到JSP文件中。