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()方法就可以了。

下面是一个标签处理类的代码式样:

Java代码
 
  1. public class MyTag extends TagSupport {  
  2.   
  3. private String prop1;  
  4. private String prop2;  
  5.   
  6.     /** 
  7.      *  
  8.      */  
  9.     private static final long serialVersionUID = -8771409930058657336L;  
  10.       
  11.     @Override  
  12.     //对于结束标签的返回值主要有两种EVAL_PAGE和SKIP_PAGE,前者表示继续执行结束标签以后的内容,后者表示忽略结束标签以后的内容;  
  13.     public int doEndTag() throws JspException {  
  14.         // TODO Auto-generated method stub  
  15. //这里面可以处理自己的逻辑,然后选择返回值,如果不处理,调用super.doEndTag()则会返回EVAL_PAGE  
  16. //      return EVAL_PAGE;  
  17. //      return SKIP_PAGE;  
  18.         return super.doEndTag();  
  19.     }  
  20.   
  21.     @Override  
  22.     /** 
  23.      * 对于开始标签来说返回值主要有EVAL_BODY_INCLUDE和SKIP_BODY,前者表示执行标签体,后者表示略过标签体 
  24.      */  
  25.     public int doStartTag() {  
  26.         // TODO Auto-generated method stub  
  27. //同样这里面也是执行自己的逻辑,然后来决定是要显示标签体  
  28. //可以使用两个内部属性,parent和pageContext  
  29.         if (yourCondition)  
  30.             return EVAL_BODY_INCLUDE;  
  31.         else  
  32.             return SKIP_BODY;  
  33.     }  
  34. //省略get和set方法  
  35. }  

 

 

接下来是要在WEB-INF下面新建.tld文件,名称随便取,这个tld文件是对标签库的描述,包括该标签库里面包括哪些标签和和方法,以及对标签属性等的描述,有了这个文件以后,在WEB服务器启动的时候,系统就会将该文件加载,然后当在页面上使用该标签库的时候系统就会到已经在WEB-INF目录下加载的tld文件里面去找相应的标签库,如果没有则会出错!

下面是tld文件的一个样式:

 

Xml代码
 
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2.   
  3. <taglib xmlns="http://java.sun.com/xml/ns/j2ee"  
  4.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.   xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"  
  6.   version="2.0">  
  7.       
  8.   <tlib-version>1.0</tlib-version><!-- 版本号 -->  
  9.   <short-name>my</short-name><!-- 名称随便取 -->  
  10.   <uri>http://www.test.com/core</uri><!-- 这个uri即在页面上进行引入的时候的uri -->  
  11.     
  12.   <function><!-- 这是对方法的定义,对方法的定义比较简单,只要该方法是公共的并且是静态的就可以了,该类也不需要继承什么类和接口 -->  
  13.     <name>funcTest</name><!-- 方法名 -->  
  14.     <function-class>com.test.util.Util</function-class><!-- 方法所在的类 -->  
  15.     <!-- 方法的一些信息,boolean表示返回类型, funcName表示方法名,后面是参数类型,对于其他非基本类型的数据一定要用全称,如java.lang.String-->  
  16.     <function-signature>boolean funcName(int,int,int)</function-signature>  
  17.   </function>  
  18.     
  19.   <tag>  
  20.     <name>tagName</name><!-- 标签名称,在使用的时候以前缀加这个名称使用的 -->  
  21.     <tag-class>com.test.web.tag.MyTag</tag-class><!-- 标签类 -->  
  22.     <attribute>  
  23.         <name>prop1</name><!-- 标签类里面的属性名称 -->  
  24.         <required>true</required><!-- 是否必须有 -->  
  25.     </attribute>  
  26.     <attribute>  
  27.         <name>prop2</name>  
  28.         <required>true</required>  
  29.     </attribute>  
  30.   </tag>  
  31. </taglib>  

 

之后就可以在页面上直接引入该标签库使用自定义的标签了:

如:

Java代码
 
  1. <%@taglib prefix="my" uri="http://www.test.com/core" %>  
  2. //使用<my:myTag prop1="" prop2="">content</my:myTag>  

 

对于自定的方法的使用则是要利用jstl来使用:

在导入了jstl的标签以后,可以这样使用:

${my:funcName(arg0,arg1,arg2)},这个参数的类型是需要匹配的,

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。