在模块中出现公用的菜单栏,如果每一页都单独有一个菜单栏维护起来很麻烦,每次增加一个菜单的话,菜单中的每个页面都需要修改菜单栏,稍有不慎,就会出现样式不一样的情况。
这时候就需要用到jsp的包含机制。包含机制有两种:include指令和<jsp:include/>标准动作。
<%@ include file=“ /jsp/widget/user/menuNavl.jsp"%>
<jsp:include page=“ /jsp/widget/user/menuNavl.jsp”/>
include指令告诉容器:复制所包含文件中的所有内容,再把它黏贴到这个文件中,而且就放在其中。
<jsp:include>标准动作和include指令看上去一样,而且通常有相同的结果,但是看生成的servlet,就会发现不同。
下图是菜单页面menuNavl.jsp,为简单起见,我只截取了其中一部分
下图为生成的servlet,menuNavl_jsp.java
使用include指令生成的servlet,include指令取menuNavl.jsp的内容,在转换前放在include指令引用页面。
使用<jsp:include/>标准动作的JSP生成的servlet,menuNavl.jsp页面不放在引用页面生成的servlet中,是一个运行时调用。
也就是说,include指令在转换时插入menuNavl.jsp的源代码,而<jap:include/>标准动作在运行时插入menuNavl.jsp的响应。
在使用include指令的时候在第一次请求的时候需要做转换,从第二次请求开始,就再没有额外的运行时开销了。
在<jsp:include/>标准动作,转换时没有做多少工作,但是在每次请求的时候需要做拼接,每次请求都有一些运行时开销。
使用<jsp:include/>标准动作的好处是能保证每次都能看到最新的内容,include指令在现在新的容器变化可见中也能重新转换最新文件。
因此在平常使用中推荐使用include指令包含引用JSP。
现在有这样一个应用场景,JSP包含一个公共的菜单列表页面,这个菜单列表页面,点击菜单跳转到目标页面,需要根据跳转的页面,在菜单上把相应页面的名称颜色做改变。
我们引入EL函数就能帮我们实现需求。
实现EL函数你需要四步实现:
一、编写有一个公共静态方法的Java类。
有函数的类,必须是公共、静态的方法。
二、编写一个标记库描述文件(TLD)
三、在JSP中放一个taglib指令。
四、使用EL调用函数。
根据判断的结果,后台设定menuNavl属性的值,如果返回的值和userManage的值相等,文字的样式中就添加on的样式,这样就可以根据访问的页面动态返回需要的样式。
本文为头条号作者发布,不代表今日头条立场。