Jsp自定義標簽和方法詳解
首先是要有一個標簽處理類,標簽處理類可以直接實現(xiàn)Tag接口,也可以繼承Java中已經(jīng)實現(xiàn)了的TagSupport這個類,TagSupport也是繼承自Tag接口的,它內部已經(jīng)對Tag接口進行了實現(xiàn),一般是繼承TagSupport類,之后是重寫父類的doStartTag和doEndTag方法,
對于開始標簽來說返回值主要有EVAL_BODY_INCLUDE和SKIP_BODY,前者表示執(zhí)行標簽體,后者表示略過標簽體;
對于結束標簽的返回值主要有兩種EVAL_PAGE和SKIP_PAGE,前者表示繼續(xù)執(zhí)行結束標簽以后的內容,后者表示忽略結束標簽以后的內容;另外,在繼承自TagSupport類的標簽處理類里面還有兩個隱含的屬性,一個是parent,表示該標簽上層標簽的處理類,另外一個是pageContext,pageContext是為了方便我們使用的WEB元素而引入的一個屬性,像HttpSession之類的;實現(xiàn)了Tag接口的類也可以使用這兩個隱含屬性,只需要實現(xiàn)其中的setParent()方法和setPageContext()方法就可以了。
下面是一個標簽處理類的代碼式樣:
public class MyTag extends TagSupport { private String prop1; private String prop2; /** * */ private static final long serialVersionUID = -8771409930058657336L; @Override //對于結束標簽的返回值主要有兩種EVAL_PAGE和SKIP_PAGE,前者表示繼續(xù)執(zhí)行結束標簽以后的內容,后者表示忽略結束標簽以后的內容; public int doEndTag() throws JspException { // TODO Auto-generated method stub //這里面可以處理自己的邏輯,然后選擇返回值,如果不處理,調用super.doEndTag()則會返回EVAL_PAGE // return EVAL_PAGE; // return SKIP_PAGE; return super.doEndTag(); } @Override /** * 對于開始標簽來說返回值主要有EVAL_BODY_INCLUDE和SKIP_BODY,前者表示執(zhí)行標簽體,后者表示略過標簽體 */ public int doStartTag() { // TODO Auto-generated method stub //同樣這里面也是執(zhí)行自己的邏輯,然后來決定是要顯示標簽體 //可以使用兩個內部屬性,parent和pageContext if (yourCondition) return EVAL_BODY_INCLUDE; else return SKIP_BODY; } //省略get和set方法 }
接下來是要在WEB-INF下面新建.tld文件,名稱隨便取,這個tld文件是對標簽庫的描述,包括該標簽庫里面包括哪些標簽和和方法,以及對標簽屬性等的描述,有了這個文件以后,在WEB服務器啟動的時候,系統(tǒng)就會將該文件加載,然后當在頁面上使用該標簽庫的時候系統(tǒng)就會到已經(jīng)在WEB-INF目錄下加載的tld文件里面去找相應的標簽庫,如果沒有則會出錯!
下面是tld文件的一個樣式:
?xml version="1.0" encoding="UTF-8" ?> taglib xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd" version="2.0"> tlib-version>1.0/tlib-version>!-- 版本號 --> short-name>my/short-name>!-- 名稱隨便取 --> uri>http://www.test.com/core/uri>!-- 這個uri即在頁面上進行引入的時候的uri --> function>!-- 這是對方法的定義,對方法的定義比較簡單,只要該方法是公共的并且是靜態(tài)的就可以了,該類也不需要繼承什么類和接口 --> name>funcTest/name>!-- 方法名 --> function-class>com.test.util.Util/function-class>!-- 方法所在的類 --> !-- 方法的一些信息,boolean表示返回類型, funcName表示方法名,后面是參數(shù)類型,對于其他非基本類型的數(shù)據(jù)一定要用全稱,如java.lang.String--> function-signature>boolean funcName(int,int,int)/function-signature> /function> tag> name>tagName/name>!-- 標簽名稱,在使用的時候以前綴加這個名稱使用的 --> tag-class>com.test.web.tag.MyTag/tag-class>!-- 標簽類 --> attribute> name>prop1/name>!-- 標簽類里面的屬性名稱 --> required>true/required>!-- 是否必須有 --> /attribute> attribute> name>prop2/name> required>true/required> /attribute> /tag> /taglib>
之后就可以在頁面上直接引入該標簽庫使用自定義的標簽了:
如:
%@taglib prefix="my" uri="http://www.test.com/core" %> //使用my:myTag prop1="" prop2="">content/my:myTag>
對于自定的方法的使用則是要利用jstl來使用:
在導入了jstl的標簽以后,可以這樣使用:
${my:funcName(arg0,arg1,arg2)},這個參數(shù)的類型是需要匹配的,
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
下一篇:JSP 導出Excel表格的實例