欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Jsp自定義標簽和方法詳解

 更新時間:2017年06月14日 17:22:36   投稿:lqh  
這篇文章主要介紹了Jsp自定義標簽和方法詳解的相關資料,需要的朋友可以參考下

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ù)的類型是需要匹配的,

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

最新評論