|
這里所討論的模板將在三種定制標(biāo)簽下執(zhí)行:
Template: insert
Template: put
Template: get
insert 標(biāo)簽中包含一個(gè)模板,但是在包含之前,put 標(biāo)簽存儲(chǔ)有一些信息――name, URI和Boolean 值(用來(lái)指定將內(nèi)容是包含還是直接顯示)――關(guān)于模板所包含的內(nèi)容。在template:get中包含(或顯示)了指定的內(nèi)容,隨后將訪問(wèn)這些信息。
template:put 把Bean 存儲(chǔ)在請(qǐng)求區(qū)域(但并不直接存儲(chǔ)),因?yàn)槿绻麅蓚€(gè)模板使用了相同的內(nèi)容名,一個(gè)嵌套模板就將覆蓋封裝模板中的內(nèi)容。
為了保證每一個(gè)模板能夠只存取它自己的信息,template:insert 保留了一個(gè)hashtable堆棧。每一個(gè)insert 開始標(biāo)簽建立一個(gè) hashtable并把它放入堆棧。封裝的put 標(biāo)簽建立bean并把它們保存到最近建立的hashtable中。隨后,在被包含模板中的 get 標(biāo)簽訪問(wèn)hashtable中的bean。圖 4 顯示了堆棧是如何被保留的。
圖 4. 在請(qǐng)求區(qū)域存儲(chǔ)模板參數(shù) 點(diǎn)擊放大(24 KB)
在圖 4中每一個(gè)模板訪問(wèn)正確的頁(yè)腳、footer.html 和footer_2.html。如果 bean被直接存儲(chǔ)在請(qǐng)求區(qū)域,圖 4中的step 5將覆蓋在step 2中指定的footer bean。
模板標(biāo)簽執(zhí)行
接下來(lái)我們將分析三個(gè)模板標(biāo)簽的執(zhí)行: insert, put和get。我們先從圖 5開始。這個(gè)圖表說(shuō)明了當(dāng)一個(gè)模板被使用時(shí),insert和put標(biāo)簽事件的執(zhí)行順序。
圖 5. put和insert 標(biāo)簽執(zhí)行順序 點(diǎn)擊放大(24 KB)
如果一個(gè)模板堆棧已經(jīng)不存在,insert 開始標(biāo)簽就會(huì)建立一個(gè)并把它放置到請(qǐng)求區(qū)域。隨后一個(gè)hashtable也被建立并放到堆棧中。
每一個(gè) put 開始標(biāo)簽建立一個(gè)PageParameter bean,并存儲(chǔ)在由封裝的insert標(biāo)簽建立的hashtable中。
插入 end 標(biāo)簽包含了這個(gè)模板。這個(gè)模板使用get標(biāo)簽來(lái)訪問(wèn)由put標(biāo)簽建立的bean。在模板被處理以后,由insert 開始標(biāo)簽建立的hashtable就從堆棧中清除。
圖 6顯示template:get的順序圖表。
圖 6. get標(biāo)簽的順序圖表 點(diǎn)擊放大(11 KB)
模板標(biāo)簽列表
標(biāo)簽handler很簡(jiǎn)單。在例 3.a中列出了Insert標(biāo)簽類――標(biāo)簽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標(biāo)簽類和標(biāo)簽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建立了一個(gè) PageParameter bean 主站蜘蛛池模板: 午夜在线观看免费完整直播网页 | 18 japanese宾馆直播 | 欧美亚洲另类丝袜自拍动漫 | 亚洲免费每日在线观看 | 国产精品嫩草99AV在线 | 香蕉鱼视频观看在线视频下载 | 天天狠狠色噜噜 | 青青伊人网 | 亚洲 欧美 日本 国产 高清 | 高h辣h双处全是肉一对一 | 牛牛在线精品视频 | 久久精品国产亚洲AV蜜臀 | 美女在线永久免费网站 | 十分钟免费观看大全视频 | 色婷婷激情AV精品影院 | 日韩精品无码视频一区二区蜜桃 | 亚洲熟女片嫩草影院 | 国产精品久久久久久久久久久 | 色综合a在线 | 亚洲AV无码一区二区三区乱子伦 | 国产午夜精品视频在线播放 | 护士日本ⅹxxx丰满hd | 24小时日本在线观看片 | 黑人开嫩苞 | av亚洲2017色天堂 | 青青久在线视频免费观看 | 97精品一区二区视频在线观看 | 色欲AV精品人妻一区二区三区 | 特级aa 毛片免费观看 | 国产精品欧美一区二区在线看 | free性中国hd护士高清 | 日本高清无吗 | 99久久精品费精品蜜臀AV | 亚洲高清无在码在线无弹窗 | 亚洲国产精品久久人人爱 | 色戒无删减流畅完整版 | 亚洲一区二区三区乱码在线欧洲 | 伊人久久大香线蕉avapp下载 | 一受多攻高h | 老司机无码精品A | 内射白嫩少妇超碰 |