前者是指令元素、后者是行为元素。具体它们将在何处用?如何用及它们有什么区别?这应该是很多人看到它都会想到的问题。下面一起来看看吧。 通常当应用程序中所有的页面的某些部分(例如标题、页脚和导航栏)都相同的时候,我们就可以考虑用include。具体在哪些时候用<%@ include file=\"\"%>,哪些时候用 两者最重要的区别:JSP指令<%@ include file=\"\"%>,是将被引入的JSP与原JSP融合到一起,而这个融合过程是在翻译阶段进行的。 为什么需要翻译阶段?我们知道,jsp页面并不是原封不动的发送到客户端的,因为浏览JSP页面的客户端并不需要安装Java虚拟机,客户端机器并不能读 懂JSP,它能读懂的只有HTML、JavaScript (当然还有其他,例如:Applet、Flex、AxtiveX等等,但那些都需要下载相应的客户端解析器),这样就需要Servlet Engine (例如:Tomcat) 将所有的JSP元素进行处理。这是通过将jsp页面转化成Servlet,然后执行这个Servlet来完成的。服务器需要一个jsp容器来处理jsp页 面。jsp容器通常以Servlet的形式实现,这个servlet经过配置,可以处理对jsp页面的所有请求。 JSP容器负责将jsp页面转化成servlet,并编译这个servlet。这两个步骤就构成了翻译阶段。 而jsp翻译之后的servlet输出的内容才是客户端浏览器能够识别的东西,HTML、JavaScript之类的,servlet是使用 JspWriter对象输出输出这些HTML、JavaScript的。如果你去翻看翻看jsp编译后的servlet代码,你会发现很有意思的东西,比 如Struts的 do{}while()语句实现循环。如果我们 把 _jspx_meth_bean_write_2(_jspx_th_logic_iterate_0, _jspx_page_context)的方法调用。这些说明了一切。 由此我们知道:jsp页面是把include指令元素(<%@ include file=\"\"%>)所指定的页面的实际内容(也就是代码段)加入到引入它的jsp页面中,合成一个文件后被jsp容器将它转化成servlet。 可以看到这时会产生一个临时class文件和一个servlet源文件。而动作元素( Html代码 1. <%@ page language=\"java\" pageEncoding=\"GBK\"%> 2. 3. <%@ taglib uri=\"http://struts.apache.org/tags-bean\" prefix=\"bean\" %> 4. <%@ taglib uri=\"http://struts.apache.org/tags-html\" prefix=\"html\" %> 5. <%@ taglib uri=\"http://struts.apache.org/tags-logic\" prefix=\"logic\" %> 6. <%@ taglib uri=\"http://struts.apache.org/tags-tiles\" prefix=\"tiles\" %> 7. 8. 9. 10. 12. 14. 15. 16. 17. 18. 19. 20. 21. 24. 25. 26. 27. 28. 29.<%-- <%@ include file=\"include/head.jsp\"%>--%> 30. 31. 32.<%-- <%@ include file=\"include/menubar.jsp\"%>--%> 33. 34. 我是主体 44.<%-- <%@ include file=\"include/copyright.jsp\"%>--%> 45.<%-- 46.<%-- 1. <%--<%@ page language=\"java\" pageEncoding=\"GBK\"%>--%> 2. 3. <%--<%@ taglib uri=\"/WEB-INF/struts-html.tld\" prefix=\"html\" %>--%> 4. <%--<%@ taglib uri=\"/WEB-INF/struts-logic.tld\" prefix=\"logic\" %>--%> 5. <%--<%@ taglib uri=\"/WEB-INF/struts-bean.tld\" prefix=\"bean\" %>--%> 6. 7. 8. 9. 10. 我是Head 我是Head我是Head我是Head我是Head我是Head我是Head 以head.jsp为例: 1、如果我是用<%@ include file=\"include/head.jsp\"%>引入,注意,head.jsp被我注释掉的字符集和Struts标签的引入,如果打开注释,会怎么样呢??会抛出500异常,/main.jsp(44,4) /include/head.jsp(3,56) Attempt to redefine the prefix html to /WEB-INF/struts-html.tld, when it was already defined as http://struts.apache.org/tags-html in the current scope.这时因为在翻译阶段main.jsp和head.jsp被原封不动的合称为一个jsp,察看Tomcat工作目录只有一个servlet类文件。 \\work\\Catalina\\localhost\\IncludeAction\\org\\apache\\jsp\\main_jsp.java \\work\\Catalina\\localhost\\IncludeAction\\org\\apache\\jsp\\main_jsp.class 试想,在一个类文件中两次引入相同的Struts标签,编译时当然回抛出异常了。 2、那么如果我是以 1. 结果: 2. 2004-2006 版权所有 3. ????Head ????Head????Head????Head????Head????Head????Head 4. ????MenuBar 5. 我是主体... 什么原因?include动作元素是在请求阶段执行引入的,所以它引入的只是head.jsp被翻译成servlet文件中 _jspService这个方法中JspWriter这个对象的输出(out.write()方法的输出流)。该输出的执行是在head.jsp被引入 main.jsp之前就进行了,所以main.jsp页面中的字符集设置当然对head.jsp不起作用了。 如果Struts标签部分也注释掉呢?\"2004-2006 版权所有\"这一行不会输出,因为这一行是由Struts标签输出的,没有输出的原因和字符集相同,我想大家应该明白了。 最后观察Tomcat工作目录下,会有两个Servlet: 第一个: \\work\\Catalina\\localhost\\IncludeAction\\org\\apache\\jsp\\main_jsp.java \\work\\Catalina\\localhost\\IncludeAction\\org\\apache\\jsp\\main_jsp.class 第二个: \\work\\Catalina\\localhost\\IncludeAction\\org\\apache\\jsp\\include\\head_jsp.java \\work\\Catalina\\localhost\\IncludeAction\\org\\apache\\jsp\\include\\head_jsp.class 另 外,如果希望通过修改后缀的方法表示哪些是被引入的文件,例如:将head.jsp改名为head.inc的话,JSP容器不能识别*.inc。所以不能 翻译head.inc,所以此时只能使用<%@ include file=\"head.inc\"%>方法引入一个文件了。 我们来总结一下两种include 两种用法的区别,主要有两个方面的不同: 一、执行时间上: <%@ include file=”relativeURI”%> 是在翻译阶段执行 因篇幅问题不能全部显示,请点此查看更多更全内容
35. 我是主体
36. 我是主体
37. 我是主体
38. 我是主体
39. 我是主体
40. 我是主体
41. 我是主体
42. 我是主体
43. 我是主体 12. 11.