Jsp自定義標簽和方法詳解
首先是要有一個標簽處理類,標簽處理類可以直接實現Tag接口,也可以繼承Java中已經實現了的TagSupport這個類,TagSupport也是繼承自Tag接口的,它內部已經對Tag接口進行了實現,一般是繼承TagSupport類,之后是重寫父類的doStartTag和doEndTag方法,
對于開始標簽來說返回值主要有EVAL_BODY_INCLUDE和SKIP_BODY,前者表示執行標簽體,后者表示略過標簽體;
對于結束標簽的返回值主要有兩種EVAL_PAGE和SKIP_PAGE,前者表示繼續執行結束標簽以后的內容,后者表示忽略結束標簽以后的內容;另外,在繼承自TagSupport類的標簽處理類里面還有兩個隱含的屬性,一個是parent,表示該標簽上層標簽的處理類,另外一個是pageContext,pageContext是為了方便我們使用的WEB元素而引入的一個屬性,像HttpSession之類的;實現了Tag接口的類也可以使用這兩個隱含屬性,只需要實現其中的setParent()方法和setPageContext()方法就可以了。
下面是一個標簽處理類的代碼式樣:
public class MyTag extends TagSupport { private String prop1; private String prop2; /** * */ private static final long serialVersionUID = -8771409930058657336L; @Override //對于結束標簽的返回值主要有兩種EVAL_PAGE和SKIP_PAGE,前者表示繼續執行結束標簽以后的內容,后者表示忽略結束標簽以后的內容; 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,前者表示執行標簽體,后者表示略過標簽體 */ public int doStartTag() { // TODO Auto-generated method stub //同樣這里面也是執行自己的邏輯,然后來決定是要顯示標簽體 //可以使用兩個內部屬性,parent和pageContext if (yourCondition) return EVAL_BODY_INCLUDE; else return SKIP_BODY; } //省略get和set方法 }
接下來是要在WEB-INF下面新建.tld文件,名稱隨便取,這個tld文件是對標簽庫的描述,包括該標簽庫里面包括哪些標簽和和方法,以及對標簽屬性等的描述,有了這個文件以后,在WEB服務器啟動的時候,系統就會將該文件加載,然后當在頁面上使用該標簽庫的時候系統就會到已經在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><!-- 這是對方法的定義,對方法的定義比較簡單,只要該方法是公共的并且是靜態的就可以了,該類也不需要繼承什么類和接口 --> <name>funcTest</name><!-- 方法名 --> <function-class>com.test.util.Util</function-class><!-- 方法所在的類 --> <!-- 方法的一些信息,boolean表示返回類型, funcName表示方法名,后面是參數類型,對于其他非基本類型的數據一定要用全稱,如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)},這個參數的類型是需要匹配的,
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
新聞熱點
疑難解答