第一版本:
为什么要使用自定义标签呢?
主要是为了取代丑陋的JSP脚本。在HTML页面中插入JSP脚本有如下几个坏处:
JSP脚本非常丑陋,难以阅读。
JSP脚本和HTML代码混杂,维护成本高。
HTML页面中嵌入JSP脚本,导致美工人员难以参与开发。
以下是jsp开发1.1;
1.自定义一个处理类,继承BodyTagSupport类
重写以下方法:
@Override
public int doEndTag() throws JspException {
JspWriter out = pageContext.getOut(); //这里可以out自己定义的标签//return this.EVAL_PAGE;表示将这个页面返回
}
注意:要导servlet.jar包。
2,TLD是Tag Library Definition的缩写,即标签库定义,文件的后缀是tld,每个TLD文件对应一个标签库,一个标签库中可包含多个标签。TLD文件也称为标签库定义文件
配置:
<taglib>
<tlibversion>1.0</tlibversion>
<jspversion>1.1</jspversion>
<shortname>写写信息</shortname>
<uri>/取个名字</uri>
<tag>
<name>随便取个名字(如:aaa)</name>
<tag-class>包名.类名(即自定义标签处理类)</tag-class>
<body-content>jsp</body-content>
</tag>
</taglib>
taglib下有3个子元素:
tlib-version:指定该标签库实现的版本,这是一个作为标识的内部版本号,对程序没有太大的作用。
shortname:该标签库的默认短名,该名称通常也没有太大的用处。
uri:这个属性非常重要,它指定该标签库的URI,相当于指定该标签库的唯一标识。如上面斜体字代码所 示,JSP页面中使用标签库时就是根据该URI属性来定位标签库的。
除此之外,taglib元素下可以包含多个tag元素,每个tag元素定义一个标签,tag元素下至少应包含如下3个 子元素:
name:该标签库的名称,这个属性很重要,JSP页面中就是根据该名称来使用此标签的。
tag-class:指定标签的处理类,毋庸置疑,这个属性非常重要,指定了标签由哪个Java类来处理。
body-content:这个属性也很重要,它指定标签体内容。该元素的值可以是如下几个:
tagdependent:指定标签处理类自己负责处理标签体。
empty:指定该标签只能作为空标签使用。
scriptless:指定该标签的标签体可以是静态HTML元素、表达式语言,但不允许出现JSP脚本。
JSP:指定该标签的标签体可以使用JSP脚本。
在jsp文件的上方写这个:
<%@taglib uri="/WEB-INF/tld文件名(如a.tld)" prefix="随便取个名字(如:ppp)"%>
在<body><跟prefix一样的名字(如:ppp):跟上面的配置的name一样的(如:aaa)/></body>
总结一下;
在JSP页面中确定指定的标签需要两点:
标签库URI:确定使用哪个标签库。
标签名:确定使用哪个标签。
使用标签库分成以下两个步骤:
导入标签库:使用taglib编译指令导入标签库,就是将标签库和指定前缀关联起来。
使用标签:在JSP页面中使用自定义标签。
属性标签:
<!-- 配置标签属性 -->
<attribute>
<name>属性名</name>
<required>true</required>
<fragment>true</fragment>
</attribute>
name:设置属性名,子元素的值是字符串内容。
required:设置该属性是否为必需属性,该子元素的值是true或false。
fragment:设置该属性是否支持JSP脚本、表达式等动态内容,子元素的值是true或false
二、JSP自定义标签的优点
1、分离了程序逻辑和表示逻辑
2、将java代码从html中剥离,便于美工维护页面
3、减少了jsp页面中的脚步,减少了维护成本
4、提高了可重用的功能组件
第二版本:
SimpleTagSupport类别顾名思义,就是可以处理一些简单的自定义标签需求,它是在JSP 2.0之后新增的类别,对于一些简单的自订标签页求,您可以继承它来实作标签处理类别,而不用为了处理一些TagSupport、 BodyTagSuppourt类别中回传值的问题。
处理类要继承SimpleTagSupport和:
// 重写doTag方法,该方法在标签结束时生成页面内容
public void doTag() throws JspException, IOException {
// 获取页面输出流,并输出字符串
getJspContext().getOut().write("Hello World");
}
配置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">
<tlib-version>1.0</tlib-version>
<short-name>取个名字</short-name>
<uri>取个名字</uri>
<tag>
<name>取个名字</name>
<tag-class>包名.类名(即自定义标签处理类</tag-class>
<body-content>scriptless</body-content>
<!-- 以下是配置属性 -->
<attribute>
<name>属性名</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
</taglib>
例子:定义数据库的标签:
处理类:
package action;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.JspWriter;
import javax.servlet.jsp.tagext.SimpleTagSupport;
public class DBTag extends SimpleTagSupport{
private String driver=null;
private String url=null;
private String username=null;
private String password=null;
private String sql=null;
public String getDriver() {
return driver;
}
public void setDriver(String driver) {
this.driver = driver;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getSql() {
return sql;
}
public void setSql(String sql) {
this.sql = sql;
}
public void doTag() throws JspException, IOException {
// 获取页面输出流,并输出字符串
JspWriter out=getJspContext().getOut();
try {
Class.forName(driver);
Connection con=DriverManager.getConnection(url,username,password);
Statement statement=con.createStatement();
ResultSet resultSet=statement.executeQuery(sql);
out.println("<form name=login method=post>");
out.println("<table border=1 id=table style=cursor:hand bgColor='9999cc' width='400'>");
out.println("<thead>");
out.println("<tr>");
out.println("<td οnclick='sortTable(0);'>"+"学号"+"</td>");
out.println("<td οnclick='sortTable(1);'>"+"姓名"+"</td>");
out.println("<td οnclick='sortTable(2);'>"+"性别"+"</td>");
out.println("<td οnclick='sortTable(3);'>"+"年龄"+"</td>");
out.println("</tr>");
out.println("</thead>");
out.println("<tbody>");
try {
while(resultSet.next()){
out.println("<tr>");
for(int i=1;i<resultSet.getMetaData().getColumnCount()+1;i++){
out.println("<td>");
out.println(resultSet.getObject(i));
out.println("</td>");
}
out.println("</tr>");
}
} catch (Exception e) {
e.printStackTrace();
}
out.println("</tbody>");
out.println("</table>");
out.println("</form>");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
tld文件:
<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">
<tlib-version>1.0</tlib-version>
<short-name>mytag</short-name>
<uri>http://www.db.com</uri>
<tag>
<name>dbGirl</name>
<tag-class>action.DBTag</tag-class>
<body-content>scriptless</body-content>
<!-- 以下是配置属性 -->
<attribute>
<name>driver</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<name>url</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<name>username</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<name>password</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<name>sql</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
</taglib>
jsp文件:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@taglib uri="http://www.db.com" prefix="dbtag"%>
<!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>我的DBjsp页面</title>
</head>
<body>
<dbtag:dbGirl driver="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=UTF-8" username="root" password="********" sql="select * from student"></dbtag:dbGirl>
</body>
</html>
效果看以下图片: