我目前有一个叫做菜单容器的Jsp,它加载了一个应该出现在我的每个页面上的基本菜单,但每个页面都会为该菜单添加选项,这些选项会在特定的地方进行,所以我想知道我如何将内容发送到另一个菜单容器(这是一个Jsp),这里是菜单容器:
<ul id="menu">
<!-- Modificar las authorities segun la aplicacion -->
<div class="navbar navbar-default menu">
<div class="navbar-header" >
<button type="button" class="navbar-toggle collapsed"
data-toggle="collapse" data-target="#menu-colapse" aria-
expanded="false"
aria-controls="navbar">
<span class="sr-only">Menú</span> <span class="icon-bar">
</span>
<span class="icon-bar"></span> <span class="icon-bar"></span>
</button>
</div>
<!-- Menu colapse -->
<div id="menu-colapse" class="navbar-collapse collapse">
<!-- Menu usuario - para opciones de control del usuario-->
<ul class="nav navbar-nav navbar-right">
<li class="dropdown user-options">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">
<i class="fa fa-cog"></i>
<!--[if IE 7]>
Opciones <span class="caret"></span>
<![endif]-->
</a>
<!-- En este dropdown van las opciones que se necesiten en la aplicacion -->
<ul class="dropdown-menu">
<!-- Nombre del usuario, recuperado por spring -->
<li>
<a href="#" class="a-no-link">
<!--[if !IE 7]><!-->
<i class="fa fa-user fa-padding-6 fix-right-menu" aria-hidden="true"></i>
<!--<![endif]-->
<sec:authentication property="principal" />
</a>
</li>
<!-- Logout -->
<li>
<div class="form-inline" style="color: white !important; height: 23px;">
<!--[if !IE 7]><!-->
<i class="fa fa-sign-out fa-padding-6" aria-hidden="true" style="margin-left: 16px;"></i>
<!--<![endif]-->
<a href="SalirAplicacion" style="color: white !important;"><spring:message code="menuPpal.salir"/></a>
</div>
</li>
</ul>
</li>
</ul>
<ul class="nav navbar-nav navbar-right">
<li class="dropdown user-options">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">
<i class="fa fa-language"></i>
</a>
<ul class="dropdown-menu">
<li><a class="a-link" href="configuracionInicio?idioma=en&pagina=inicio" title="English">English</a></li>
<li><a class="a-link" href="configuracionInicio?idioma=es&pagina=inicio" title="Español">Español</a></li>
<li><a class="a-link" href="configuracionInicio?idioma=fr&pagina=inicio" title="Français">Français</a></li>
</ul>
</li>
</ul>
<!-- /Menu usuario -->
<ul class="nav navbar-nav navbar-right" aria-expanded="false" id="main-menu">
//This is the place for the Li Items
//One or more items to add
</ul>
现在调用Jsp的内容如下:
<jsp:include page="comun/menu-container.jsp" />
但是因为我必须从调用项目的jsp发送它(因为它是因为它们当然是彼此区分的),但我不知道怎么做,假设我把它们在一个新的Jsp中,我称之为然后如何将其传递给容器?你怎么收到它?
感谢您抽出时间欢迎任何帮助,问候!
Pdta:我想要避免的是必须有muuuchas课程菜单,只改变他们添加的内容,因为这让我的练习非常糟糕。
答案 0 :(得分:2)
您可以通过调用JSP传递额外的菜单项作为参数。
菜单-container.jsp 强>
<ul id="main-menu">
${param.menuItems}
</ul>
<强> invoking_jsp.jsp 强>
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Invoking JSP</title>
</head>
<body>
<jsp:include page="menu-container.jsp">
<jsp:param name="menuItems" value="<li>Special menu item 1</li><li>Special menu item 2</li>"/>
</jsp:include>
</body>
</html>
菜单-container.jsp 强>
<ul id="main-menu">
<jsp:include page="${param.menuItems}"/>
</ul>
<强> invoking_jsp.jsp 强>
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Invoking JSP</title>
</head>
<body>
<jsp:include page="menu-container.jsp">
<jsp:param name="menuItems" value="menuPrincipal.jsp"/>
</jsp:include>
</body>
</html>