2016-04-13 2 views
0

Я родом из PHP, где объявление и использование пользовательской функции довольно просто, чем JSP (я думаю). Для того, чтобы сделать эту задачу, я разделить шаблон HTML на несколько частей с помощью PHP функции (в файле * .php) и вызывать их по мере необходимости, так как следующим образом:Как правильно писать и вызывать пользовательскую функцию в JSP?

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>&nbsp;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() Функция автоматически добавляется на мою страницу без вызова функции. Я хочу загрузить этот код при вызове функции. i.e:

<body> 
    <%! load_navbar("Title goes here"); %> 
</body> 

Может ли кто-нибудь помочь мне исправить проблему.

ответ

1

Jsp: include сделает запрос на включение/navbar.jsp и добавит ответ на JSP с помощью jsp: include. Для вашего случая вы хотите использовать <% @ include file = "include/navbar.jsp"%>. В этом случае содержимое navbar.jsp будет добавлено во время фазы перевода в файл JSP с помощью директивы include.

Смежные вопросы