三.自定义标签的处理流程
1.自定义标签步骤
1.1 编写助手类
package com.YU.tag; import javax.servlet.jsp.JspWriter; import javax.servlet.jsp.tagext.BodyTagSupport; public class OutTag extends BodyTagSupport{ private String val; private String defaultval; public void setVal(String val) { this.val = val; } public void setDefaultval(String defaultval) { this.defaultval = defaultval; } @Override public int doStartTag() { JspWriter out = this.pageContext.getOut(); try { if(this.val==null) { out.print(this.defaultval); }else { out.print(this.val); } } catch (Exception e) { e.printStackTrace(); } return SKIP_BODY; } }
这里需要注意的是要继承BodySupport类,重写doStartTag方法,由代码中可得知,创建一个out标签,需先创建一个out对象,定义一个接受的值和一个默认值,返回时需要返回一个值
1.2 编写标签库描述文件(tld)
(1)首先新建一个xml文件在其中编写dtd约束
<!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd"> <!-- 标签库描述符 --> <taglib xmlns="http://java.sun.com/JSP/TagLibraryDescriptor"> <tlib-version>1.0</tlib-version> <jsp-version>1.2</jsp-version> <short-name>Simple Tags</short-name> <uri>YU</uri> <tag> <!--标签名 --> <name>out</name> <!--标签助手类 --> <tag-class>com.YU.tag.OutTag</tag-class> <!--标签内容类型 --> <body-content>empty</body-content> <!--属性 --> <attribute> <!-- 属性名, OutTag类中的val属性相匹配 --> <name>val</name> <!-- 表示该属性为必要的属性 --> <required>true</required> <!-- 该属性可以接受EL表示式的值 --> <rtexprvalue>true</rtexprvalue> <!-- 标签描述,用于说明标签的作用 --> <description>定义默认值</description> </attribute> </tag> </taglib>
注:标签内容类型中的empty表示为空标签,jsp则表示不为空标签
(2).依次写入标签名,标签助手类和标签所需要的一些属性
1.3 在页面上引入标签使用
<%@taglib prefix="z" uri="YU"%>
需要在jsp页面顶部第二行引入
注:uri的值为我们编写dtl文件中的uri的值,
例如这里是:
2.开发实例演示-if标签
2.1 首先编写助手类
package com.YU.tag; import javax.servlet.jsp.tagext.BodyTagSupport; public class ifTag extends BodyTagSupport{ private boolean test; public boolean isTest() { return test; } public void setTest(boolean test) { this.test = test; } @Override public int doStartTag() { if(this.test) {//说明该结果成立 return SKIP_BODY; } return SKIP_BODY; } }
2.2 编写标签库描述文件(dtl)
<!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd"> <!-- 标签库描述符 --> <taglib xmlns="http://java.sun.com/JSP/TagLibraryDescriptor"> <tlib-version>1.0</tlib-version> <jsp-version>1.2</jsp-version> <short-name>Simple Tags</short-name> <uri>YU</uri> <tag> <!--标签名 --> <name>if</name> <!--标签助手类 --> <tag-class>com.YU.tag.ifTag</tag-class> <!--标签内容类型 --> <body-content>jsp</body-content> <!--属性 --> <attribute> <!-- 属性名, OutTag类中的val属性相匹配 --> <name>val</name> <!-- 表示该属性为必要的属性 --> <required>true</required> <!-- 该属性可以接受EL表示式的值 --> <rtexprvalue>true</rtexprvalue> </attribute> </tag> </taglib>
2.3 测试使用
(1).先引入标签库使用
<%@taglib prefix="z" uri="YU"%>
(2).进行测试
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@taglib prefix="z" uri="YU"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <!-- if --> <z:if test="${100 == 100}"> 测试if(100 == 100) </z:if> <z:if test="${100 == 1}"> 测试if(100 == 1) </z:if> </body> </html>
运行结果:
测试if(100 == 100)
说明上面的if标签结果成立并打印