自定义标签为常见和重复任务的逻辑供应了一个很好的方法,它被包装在一个易于利用的包中。

要创建和利用自定义标签,我们须要实行以下操作。

1.创建标记库描述符(TLD)文件并定义一个或多个标记。

JSP下拉框传值若何应用JSP自界说标签创立下拉列表 GraphQL

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>

南昌北大青鸟软件开拓亲情为你供应