自定义标签为常见和重复任务的逻辑供应了一个很好的方法,它被包装在一个易于利用的包中。
要创建和利用自定义标签,我们须要实行以下操作。
1.创建标记库描述符(TLD)文件并定义一个或多个标记。
2.创建标记处理程序类 - 每个标记都必须有标记处理程序类。
3.在jsp页面中利用标记。
在这个例子中,我将创建一个下拉列表,它将添补来自MySQL数据库的数据。
创建标签库描述符(TLD)文件和定义标签或标记
一个TLD文件,这基本上是一个描述标签,怎么会在网页利用的主体内容类型的XML文件,标签是否接管任何属性,等等。
§tld文件的第一行是一个XML标头,指示您利用的是哪个版本的XML。
§接下来是根元素,以及此文档必须符合的XML模式的详细信息。
§TLD文件中的下一组元素,嵌套在开始和结束之间 元素,描述标记库。
§接下来是tlib-version元素
§下一个是标记库的短名称,用于标识目的。
§自定义标签的定义位于开始和结束“标签”标签之间。
JSP规范建议所有TLD文件放在WEB-INF \ tlds目录中。虽然这不是逼迫性的,将所有TLD文件放在这里供应了人们在往后找到它们的中央位置。
bari.tld
<?xml version=\"大众1.0\公众 encoding=\公众UTF-8\"大众?>
<taglib version=\"大众2.1\公众 xmlns=\"大众http://java.sun.com/xml/ns/javaee\"大众 xmlns:xsi=\"大众http://www.w3.org/2001/XMLSchema-instance\"大众 xsi:schemaLocation=\"大众http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd\公众>
<tlib-version>1.0</tlib-version>
<short-name>bari</short-name>
<uri>/WEB-INF/tlds/bari</uri>
<!-- A validator verifies that the tags are used correctly at JSP
translation time. Validator entries look like this:
<validator>
<validator-class>com.mycompany.TagLibValidator</validator-class>
<init-param>
<param-name>parameter</param-name>
<param-value>value</param-value>
</init-param>
</validator>
-->
<!-- A tag library can register Servlet Context event listeners in
case it needs to react to such events. Listener entries look
like this:
<listener>
<listener-class>com.mycompany.TagLibListener</listener-class>
</listener>
-->
<tag>
<name>user</name>
<tag-class>cte.UsersHandler</tag-class>
<body-content>scriptless</body-content>
</tag>
</taglib>
创建标记处理程序类
标签处理程序类必须扩展SimpleTagSupport。
SimpleTagSupport类供应了SimpleTag接口的默认实现,JSP规范供应了TagSupport类,您可以将其用作自己的标记处理程序的出发点。
doTag()方法包含您的代码供应的功能。
UsersHandler.java
package cte;
import java.sql.;
import javax.servlet.jsp.JspWriter;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.tagext.SimpleTagSupport;
public class UsersHandler extends SimpleTagSupport {
/
Called by the container to invoke this tag.
The implementation of this method is provided by the tag library developer,
and handles all tag processing, body iteration, etc.
/
@Override
public void doTag() throws JspException {
JspWriter out = getJspContext().getOut();
try {
// connect to database
Connection con = Database.getConnection();//create your own database handler
PreparedStatement ps = con.prepareStatement(\"大众select id, username from users order by username\"大众);
ResultSet rs = ps.executeQuery();
String output = \"大众<select name=uid>\公众;
while (rs.next()) {
output += \"大众<option value=\公众 + rs.getString(\"大众id\"大众) + \"大众>\公众 + rs.getString(\"大众username\公众) + \"大众</option>\公众;
}
output += \"大众</select>\"大众;
out.println(output);
} catch (Exception ex) {
throw new JspException(\"大众Error in UsersHandler tag\"大众, ex);
}
}
}
在JSP页面中利用标签
利用标签库哀求的标签库通过taglib指令导入。这许可您指定引用该标记库中的标记的前缀。利用我们示例的TLD文件位于WEB-INF \ tlds \ bari.tld,您可以利用以下指令直接将其导入JSP页面:
<%@ taglib prefix =“bari”uri =“/ WEB-INF / tlds / bari.tld”%>
index.jsp
<%@page contentType=\"大众text/html\公众 pageEncoding=\"大众UTF-8\公众%>
<%@ taglib prefix=\"大众bari\"大众 uri=\"大众/WEB-INF/tlds/bari.tld\"大众%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv=\"大众Content-Type\"大众 content=\"大众text/html; charset=UTF-8\"大众>
<title>JSP Page</title>
</head>
<body>
<form action=\"大众dispuser.jsp\"大众>
Select User: <bari:user /><br></br>
<input type=submit value=\"大众Show selected user\"大众/>
</form>
</body>
</html>
如果须要显示所选值,请利用此选项。
dispuser.jsp
<%@page contentType=\公众text/html\"大众 pageEncoding=\公众UTF-8\"大众%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv=\"大众Content-Type\"大众 content=\"大众text/html; charset=UTF-8\"大众>
<title>JSP Page</title>
</head>
<body>
Selected user id is: <%=request.getParameter(\"大众uid\"大众)%>
</body>
</html>
南昌北大青鸟软件开拓亲情为你供应