1、html
JSP共有下面两种include包含语句:tomcat
一、<%@ include file="uri" %>
--静态的包含页面:无论其内容如何只是将页面中的内容包含进来。
--执行过程:将全部内容包含进来一块儿处理完以后再将全部的内容发送给客户端。 服务器
二、<jsp:include page="uri">
--动态包含页面:能自动区分所包含的是静态页面仍是动态页面。
--执行过程:①若是资源为惊天资源,则直接将资源包含处理,此时的处理过程与<%@ include file="uri" %>包含相同。②若是请求资源为动态,则先各自处理资源,以后将处理后的结果包含在一块儿。jsp
2、url
何时用静态包含?何时用动态包含?spa
include指令<%
@include
file=
""
%>,这种方式的引入属于静态导入,include行为<jsp:include>,这种方式的导入属于动态的导入,这里涉及到一个jsp的原理上的问题。如今就先回顾一下:
code
当我在地址栏中输入一个JSP的地址的时候,点击回车,会提交一个请求给个人Web容器(如:tomcat,resin)等,这个容器会把这个以jsp结尾的请求对应到一个jsp引擎(其本质也是一个servlet)来处理,这个servlet必定会去先把要回应请求的jsp转义成为servlet(此时include指令被解释执行),而后,把这个servlet编译为
class
文件,由虚拟机解释执行,处理用户的请求(此时include行为执行),而后再生成响应。
htm
因此说,静态导入是在转译时发生的,是代码级的导入,这个指令的做用就是让jsp引擎去按照这个指令去作一些事情。而include动做是在请求处理阶段发生的,也就是说,include动做会产生两个servlet,二者之间能够传参数,引入的是处理后的结果。
对象
一、两个jsp页面的<%@page contentType=“text/html;charset=UTF-8”%>应该保持一致资源
二、不能经过fileurl向被包含的jsp页面传递参数,由于此静态包含是发生在jsp页面转换为servlet的转换期间,此时的参数是服务器端设置的死的参数,彻底没有通过客户端,这种参数是没有意义的,如<%@include file=“fileurl?user=admin”%>,并且此时会报错。
三、包含的jsp页面与被包含的jsp页面共用一个request内置对象。
好比说在客户端访问包含页面时地址栏后面直接加上参数后传递,这种形式的传参是客户端送来的,两个页面都可以访问此参数。咱们能够经过这两个页面合成的servlet中能够看到有传递的参数成为servlet的成员变量。
四、包含的jsp页面与被包含的jsp页面最好没有重复的html标签。不然会发生覆盖现象。
1.动态包含用的元素是page,并且有两种形式。静态包含用的元素是file,只有一种形式。
2.生成的文件不一样,静态的包含是将两个jsp文件二合一,生成一个以包含页面命名的servlet和class文件,动态包含的两个jsp文件各自生成本身的servlet和class文件。
3. 传参方式一:<jsp:include page=“a.jsp?param=123”/>时被包含的jsp页面是能够访问该参数的。
4. 传参方式二:
<jsp:include page=“a.jsp”>
<jsp:param name=“” value=“”>
<jsp:param name=“” value=“”>
</ jsp:include >
5.在客户端访问包含页面时地址栏后面直接加上参数后传递,这种形式的传参是客户端送来的,可是这两个页面中的request对象不是同一个,由于3.中已经说了包含的页面能够向被包含的页面传递参数,因此被包含的页面中的request对象含的参数个数应该大于等于包含页面的参数个数的。因此它们各有各的request对象。并且被包含的jsp页面能够访问传到包含页面的参数。
6.动态包含只有在执行到它的时候才加载,因此它才叫动态包含。