TLD文件的解释术语: 标签库描述文件,用于存放标签名字和类的映射用的 标签库:它把类标签和后面的Java类映射起来,它减少了页面的代码,使页面更加的清晰,其实标签最后还是被解释成后台的java代码 原理是,在用户在jsp页面中使用标签时,系统首先会先到xml文件中的 <taglib>标签中的《taglib-uri》和《taglib-location》这两对标签找到相对应的扩展名为tld文件,然后在 tld文件中的映射再找到相对应的taglib类。
创建的每个标签都必须在tld文件中声明,如果要在jsp页面用jsp的标签,必先先实现定义标签的类,然后在标签库描述文件(TLD)中将写好的类映射成jsp标签,然后在jsp页面中使用定义好的标签,然后就可以实现动态的jsp信息。 当需要使用自定义标签时就需要配置xml文件和tld文件 1.定义tld文件,必须位于WEB-INF目录或其子目录 PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java./dtd/web-jsptaglibrary_1_2.dtd"> <taglib xmlns="http://java./JSP/TagLibraryDescriptor"> <tlib-version>1.0</tlib-version> <jsp-version>1.2</jsp-version> <short-name>Simple Tags</short-name> <tag-class>com.OutTag</tag-class> <!-- 标签的内容类型:empty表示空标签(使用空标签会报错,不能加入值),jsp表示可以为任何合法的JSP元素 --> <body-content>JSP</body-content> <required>true</required> <rtexprvalue>true</rtexprvalue>
2 定义对应的实体类(助手类) public class OutTag extends BodyTagSupport { public Object getValue() { public void setValue(Object value) { //SKIP_BODY 从开始直接结束不走身体部分 就是不现实标签中的文字 //而super.doStartTag()默认SKIP_BODY //EVAL_BODY_INCLUDE 显示标签中的文字 //pageContext.getOut().print(value); 将属性值的信息直接输出到页面上 public int doStartTag() throws JspException { pageContext.getOut().print(value); } catch (IOException e) { // TODO Auto-generated catch block //SKIP_PAGE 结束后面的标签执行 直接到HTML的闭签 public int doEndTag() throws JspException { // TODO Auto-generated method stub
3在jsp页面中使用标签 <%@ page language="java" contentType="text/html; charset=UTF-8" <%@ taglib prefix="c" uri="http://java./jsp/jstl/core"%> <%@ taglib prefix="p" uri="/zking" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www./TR/html4/loose.dtd"> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> request.setAttribute("name", name); <p:out value="1111"></p:out> <p:out value="<%=1+1 %>"></p:out> <p:out value="${name }"></p:out>
|