jsp标签——1
- 标签语言特点
- 自定义标签的开发及使用步骤
- 标签生命周期
1、标签语言特点
<开始标签 属性=“属性值”>标签体</结束标签>
空标签
<br/>
<hr/>
<开始标签></结束标签>
<开始标签/>
ui标签
控制标签
数据标签
2、自定义标签的开发及使用步骤
2.1 创建一个标签助手类(继承BodyTagSupport)
标签属性必须助手类的属性对应、且要提供对应get/set方法
rtexprvalue
public class DemoTag extends BodyTagSupport {
private static final long serialVersionUID = 1L;
private String test;
public String getTest() {
return test;
}
public void setTest(String test) {
this.test = test;
}
@Override
public int doStartTag() throws JspException {
System.out.println("----doStartTag-----");
// return super.doStartTag();
return EVAL_BODY_INCLUDE;
}
@Override
public int doEndTag() throws JspException {
System.out.println("----doEndTag-----");
return super.doEndTag();
}
@Override
public int doAfterBody() throws JspException {
System.out.println("----doAfterBody-----");
return super.doAfterBody();
//return EVAL_BODY_AGAIN;
}
}
2.2 创建标签库描述文件(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">
<description>zking 1.1 core library</description>
<display-name>zking core</display-name>
<tlib-version>1.1</tlib-version>
<short-name>c</short-name>
<uri>/zking</uri>
<validator>
<description>
Provides core validation features for JSTL tags.
</description>
<validator-class>
org.apache.taglibs.standard.tlv.JstlCoreTLV
</validator-class>
</validator>
<tag>
<!-- 标签库中的标签名 -->
<name>demo</name>
<!-- 标签对应的助手类的全路径名 -->
<tag-class>com.zking.DemoTag</tag-class>
<!-- jsp -->
<body-content>JSP</body-content>
<attribute>
<!-- 属性名 -->
<name>test</name>
<!-- 属性值是否必填 -->
<required>false</required>
<!-- 是否支持表达式 -->
<rtexprvalue>false</rtexprvalue>
</attribute>
</tag>
</taglib>
注:tld文件必须保存到WEB-INF目录或其子目录
2.3 在JSP通过taglib指令导入标签库,并通过指定后缀
访问自定义标签
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%-- <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> --%>
!!!在此导入自己定义的标签名
<%@ taglib uri="/zking" prefix="z" %>
<%-- <%@taglib uri="http://java.sun.com/jsp/jstl/fmt" %> --%>
<!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>
<z:demo test="xxxx">zzz</z:demo>
</body>
</html>
总结:
凡是继承了BodyTagSupport就是一个标签助手类
1、默认情况,如果jsp上有标签体 那么三个方法都会执行、
如果没有标签体,那么doAfterBody方法不会执行
2、人为改变默认设置:
a、此时jsp上有标签体,人为将doStartTag的返回值改为skip_body,那么doAfterBody也不会执行
b、如果改变doAfterBody的默认返回值为EVAL_BODY_AGAIN,那么doAfterBody方法会反复执行
SKI P_BODY:跳过主体
EVAL_BODY_INCLUDE:计算标签主体内容并[输出]
EVAL_BODY_BUFFERED:计算标签主体内容并[缓存]
EVAL_PAGE:计算页面的后续部分
SKIP_PAGE:跳过页面的后续部分
EVAL_BODY_AGAIN:再计算主体一次
3、标签生命周期
3.1 (主要用开发简单标签)
实例化标签助手类->doStartTag()------------->doEndTag()
3.2 实例化标签助手类->doStartTag()------------->doAfterBody---------------->doEndTag()…