• pageContext对象


    PageContext类主要的描述的是的JSP页面的上下文环境可以获取servlet的信息、也可以将当前JSP的上下文环境传递给指定的类实现对JSP页面的操作

    <%
    
    out.write( (pageContext.getRequest() == request ) + "<br/>");
    
    out.write( (pageContext.getResponse() == response ) + "<br/>");
    
    out.write( (pageContext.getSession() == session ) + "<br/>");
    
    out.write( (pageContext.getServletConfig() == config ) + "<br/>");
    
    out.write( (pageContext.getServletContext() == application ) + "<br/>");
    
    out.write( (pageContext.getPage() == page ) + "<br/>");
    
    out.write( (pageContext.getException() == exception ) + "<br/>");
    
    out.write( (pageContext.getOut() == out ) + "<br/>");
    
    %>

    思考:为什么SUN公司需要将其他八大对象通过pageContext也要进行获取?

    因为以后如果需要一个普通的java类来处理JSP页面数据那么直接将PageContext类传递过去即可。如:自定义标签。

    3. 设置和获取不同域属性(重点)

    <%-- 给不同的域对象设置属性 --%>

    <%

    pageContext.setAttribute("page","this is current page");       pageContext.setAttribute("name","lucy",PageContext.REQUEST_SCOPE);

    pageContext.setAttribute("age","38",PageContext.SESSION_SCOPE);

    String likes[] = {"football","sleep","basketball"};        pageContext.setAttribute("likes",likes,PageContext.APPLICATION_SCOPE);

    %>

    <%-- 获取域属性 --%>

    <%= pageContext.getAttribute("page") %><br/>

    <%= pageContext.getAttribute("name",PageContext.REQUEST_SCOPE) %><br/>

    <%= pageContext.getAttribute("age",PageContext.SESSION_SCOPE) %><br/>

    <%= Arrays.toString( (String[])pageContext.getAttribute("likes",PageContext.APPLICATION_SCOPE) ) %><br/>

    总结:

    使用pageContext设置和获取域属性的时候可以显示的指定域,如果没有指定域,那么默认该域是page域。

    问题:

    在实际的开发中设置属性和获取属性是分别由不同的程序员开发的程序,那么如果在获取的时候开发者不明确这样的属性名到底存储在哪一个域中,那么应该怎么办?

    解决方案:可以使用以下语句

    <%=  pageContext.findAttribute("test") %>

    该语句默认从pageàrequestàsessionàapplication逐个查找需要的属性,如果找到直接返回。

    因此该语句就是EL表达式的底层实现原理。

    转自:https://www.cnblogs.com/friends-wf/p/3734370.html

  • 相关阅读:
    如何实现Iframe透明
    ListView(未完)
    我又回来了
    前言
    代码重用and思路重用
    图片上传
    千万数量级分页存储过程
    MSSQL中,将text,ntext转换为int型数据
    优秀的回复,来自圣殿骑士
    SqlDataSource控件
  • 原文地址:https://www.cnblogs.com/isme-zjh/p/11882172.html
Copyright © 2020-2023  润新知