我正在尝试根据我所在的页面设置列表元素的类(放在头文件中)。头文件将导入到每个页面中。
这个项目正在使用Spring框架。我是Java Servlets的新手,我习惯于以简单的方式在.NET中执行此操作。我想知道在Java / JSP中最合适的方法是什么。
这是标题页(header.jsp):
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>My Project</title>
</head>
<body>
<div id="mainHeaderDiv" class="header main">
<div class="header_resize">
<div class="clr"></div>
<div class="menu_nav">
<ul>
<li id="liHome"><a href="./Home.htm">Home</a></li>
<li id="liOrderInfo"><a href='./OrderInfo.htm'><span>Delivery Info</span></a></li>
<li id="liInvoice"><a href='./Invoice.htm'><span>Invoice Info</span></a></li>
<li id="liShipment"><a href='./Shipment.htm'><span>Sales Order Info</span></a></li>
<li id="liMaterial"><a href='./Material.htm'><span>Material Info</span></a></li>
<li id="liLogout"><a href="./logout.htm">Logout</a></li>
</ul>
</div>
<div class="clr"></div>
</div>
</div>
</body>
</html>
我将上述标题导入(home.jsp)的其中一个页面:
<%@include file="./header.jsp" %>
<div >
<div class="content">
<div class="content_resize">
<div class="clr"></div>
<div>
<div class="article">
<c:if test="${companyInfo != null}">
<h2>
<span>Company Profile</span>
</h2>
<b> <u>Company Information</u>
</b>
<table>
<tr>
<td></td>
</tr>
</table>
</c:if>
<div class="clr"></div>
</div>
</div>
</div>
</div>
</div>
控制器方法:
@RequestMapping(value = "/Home", method = RequestMethod.GET)
public String home(@ModelAttribute("user") User user, Model model) {
logger.debug("BEGIN");
/*
.
.
.
*/
logger.debug("END");
return "Home";
}
(删除脚本和导入以便更容易阅读实际代码。)
所以当我在主页上时,这是突出“主页”菜单选项的最佳方式,如果可能的话?
答案 0 :(得分:1)
所以我意识到我们可以直接在javascript代码中使用EL。
我通过了我想从控制器中选择的li的id:
@RequestMapping(value = "/Home", method = RequestMethod.GET)
public String home(@ModelAttribute("user") User user, Model model) {
logger.debug("BEGIN");
/*
.
.
.
*/
logger.debug("END");
model.addAttribute("currPage", "liHome");
return "Home";
}
并在头页面上的javascript函数中使用它,如下所示:
window.onload = function(){
var menuToActivate = '${currPage}';
document.getElementById(menuToActivate).className = 'active';
};