這里所討論的模板將在三種定制標簽下執行:

  Template: insert

  Template: put

  Template: get

  insert 標簽中包含一個模板,但是在包含之前,put 標簽存儲有一些信息――name, URI和Bo " /> 成年女人色毛片免费,欧美2019高清hd巨大,国产精品久久久久影院色老大

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JSP模板應用指南(下)

執行模板
  這里所討論的模板將在三種定制標簽下執行:

  Template: insert

  Template: put

  Template: get

  insert 標簽中包含一個模板,但是在包含之前,put 標簽存儲有一些信息――name, URI和Boolean 值(用來指定將內容是包含還是直接顯示)――關于模板所包含的內容。在template:get中包含(或顯示)了指定的內容,隨后將訪問這些信息。

  template:put 把Bean 存儲在請求區域(但并不直接存儲),因為如果兩個模板使用了相同的內容名,一個嵌套模板就將覆蓋封裝模板中的內容。

  為了保證每一個模板能夠只存取它自己的信息,template:insert 保留了一個hashtable堆棧。每一個insert 開始標簽建立一個 hashtable并把它放入堆棧。封裝的put 標簽建立bean并把它們保存到最近建立的hashtable中。隨后,在被包含模板中的 get 標簽訪問hashtable中的bean。圖 4 顯示了堆棧是如何被保留的。


  圖 4. 在請求區域存儲模板參數 點擊放大(24 KB)

  在圖 4中每一個模板訪問正確的頁腳、footer.html 和footer_2.html。如果 bean被直接存儲在請求區域,圖 4中的step 5將覆蓋在step 2中指定的footer bean。

模板標簽執行
  接下來我們將分析三個模板標簽的執行: insert, put和get。我們先從圖 5開始。這個圖表說明了當一個模板被使用時,insert和put標簽事件的執行順序。


  圖 5. put和insert 標簽執行順序 點擊放大(24 KB)

  如果一個模板堆棧已經不存在,insert 開始標簽就會建立一個并把它放置到請求區域。隨后一個hashtable也被建立并放到堆棧中。

  每一個 put 開始標簽建立一個PageParameter bean,并存儲在由封裝的insert標簽建立的hashtable中。

  插入 end 標簽包含了這個模板。這個模板使用get標簽來訪問由put標簽建立的bean。在模板被處理以后,由insert 開始標簽建立的hashtable就從堆棧中清除。

  圖 6顯示template:get的順序圖表。


  圖 6. get標簽的順序圖表 點擊放大(11 KB)

模板標簽列表
  標簽handler很簡單。在例 3.a中列出了Insert標簽類――標簽handler。

  例 3.a. InsertTag.Java

  packagetags.templates;

  import Java.util.Hashtable;

  import Java.util.Stack;

  import Javax.servlet.jsp.JspException;

  import Javax.servlet.jsp.PageContext;

  import Javax.servlet.jsp.tagext.TagSupport;

  public class InserttagextendstagSupport {

   private Stringtemplate;

   private Stack stack;

   // setter method fortemplate 屬性

   public void setTemplate(Stringtemplate) {

     this.template =template;

   }

   public int doStartTag() throws JspException {

     stack = getStack(); // obtain a reference to thetemplate stack

     stack.push(new Hashtable()); // push new hashtable onto stack

     return EVAL_BODY_INCLUDE; // pass tagbody through unchanged

   }

   public int doEndTag() throws JspException {

     try {

       pageContext.include(template); // includetemplate

     }

     catch(Exception ex) { // IOException or ServletException

       throw new JspException(ex.getMessage()); // recast exception

     }

     stack.pop(); // pop hashtable off stack

     return EVAL_PAGE; // evaluate the rest of the page after the tag

   }

   // taghandlers should always implement release() because

   // handlers can be reused by the JSP container

   public void release() {

     template = null;

     stack = null;

   }

   public Stack getStack() {

     // try to get stack from request scope

     Stack s = (Stack)pageContext.get屬性(

              "template-stack",

              PageContext.REQUEST_SCOPE);

     // if the stack's not present, create a new one和

     // put it into request scope

     if(s == null) {

       s = new Stack();

       pageContext.set屬性("template-stack", s,

              PageContext.REQUEST_SCOPE);

     }

     return s;

   }

  }

  例 3.b 列出了 Put標簽類和標簽handler:

  例 3.b. PutTag.Java

  packagetags.templates;

  import Java.util.Hashtable;

  import Java.util.Stack;

  import Javax.servlet.jsp.JspException;

  import Javax.servlet.jsp.tagext.TagSupport;

  import beans.templates.PageParameter;

  public class PuttagextendstagSupport {

   private String name, content, direct="false";

   // setter methods for Put tag attributes

   public void setName(String s) { name = s; }

   public void setContent(String s) {content = s; }

   public void setDirect(String s) { direct = s; }

   public int doStartTag() throws JspException {

     // obtain a reference to enclosing insert tag

     Inserttagparent = (InsertTag)getAncestor(

                 "tags.templates.InsertTag");

     // puttags must be enclosed in an insert tag

     if(parent == null)

       throw new JspException("PutTag.doStartTag(): " +

                  "No Inserttagancestor");

     // gettemplate stack from insert tag

     Stacktemplate_stack = parent.getStack();

     //template stack should never be null

     if(template_stack == null)

       throw new JspException("PutTag: notemplate stack");

     // peek at hashtable on the stack

     Hashtable params = (Hashtable)template_stack.peek();

     // hashtable should never be null either

     if(params == null)

       throw new JspException("PutTag: no hashtable");

     // put a new PageParameter in the hashtable

     params.put(name, new PageParameter(content, direct));

     return SKIP_BODY; // not interested in tagbody, if present

   }

   // taghandlers should always implement release() because

   // handlers can be reused by the JSP container

   public void release() {

     name = content = direct = null;

   }

   // convenience method for finding ancestor names with

   // a specific class name

   privatetagSupport getAncestor(String className)

                   throws JspException {

     Class klass = null; // can't name variable "class"

     try {

       klass = Class.forName(className);

     }

     catch(ClassNotFoundException ex) {

       throw new JspException(ex.getMessage());

     }

     return (TagSupport)findAncestorWithClass(this, klass);

   }

  }

  PutTag.doStarttag建立了一個 PageParameter bean 主站蜘蛛池模板: 日韩一区二区三区精品 | 免费夜色污私人影院网站 | 美女逼逼毛茸茸 | 欧美重口绿帽video | xxxxxx视频| 国产欧美一区二区三区在线看 | 日本邪恶少女漫画大全 | 手机在线观看mv网址 | 欧美午夜免费观看福利片 | 久久中文字幕人妻熟AV女蜜柚M | 伊人狠狠丁香婷婷综合尤物 | 亚洲日本一区二区三区在线不卡 | 天天插天天射天天干 | 亚洲精品伊人久久久久 | 97精品国产自产在线观看永久 | 日本邪恶全彩工囗囗番海贼王 | 首页_亚洲AV色老汉影院 | 色欲AV精品人妻一区二区三区 | 小舞被爆操 | 影音先锋电影资源av | 国产麻豆剧看黄在线观看 | 热99re久久精品国产首页 | 国产在线一区二区三区四区 | 精品久久香蕉国产线看观看麻豆 | 美女打开双腿扒开屁股男生 | 肉肉高潮液体高干文H | 99久久精品国产亚洲AV | 国内九一激情白浆发布 | 不戴套挺进人妻怀孕 | 无套内射纹身女视频 | 果冻传媒2021一二三区 | 国产成人在线观看免费网站 | 久久蜜视频 | 我年轻漂亮的继坶2中字在线播放 | 夜色福利院在线观看免费 | 贵妃高h荡肉呻吟np杨玉环 | 亚洲精品视频在线免费 | 亚洲综合日韩在线2019 | 99久久就热视频精品草 | japanese from色系| 国产免费麻传媒精品国产AV |