由于传统标签使用三个标签接口来完成不同的功能,显得过于繁琐,不利于标签技术的推广, SUN公司为降低标签技术的学习难度,在JSP 2.0中定义了一个更为简单、便于编写和调用的SimpleTag接口来实现标签的功能。实现SimpleTag接口的标签通常称为简单标签。简单标签共定义了5个方法:
- setJspContext方法
用于把JSP页面的pageContext对象传递给标签处理器对象 - setParent
用于把父标签处理器对象传递给当前标签处理器对象 - getParent方法
用于获得当前标签的父标签处理器对象 - setJspBody方法
用于把代表标签体的JspFragment对象传递给标签处理器对象 - doTag方法
用于完成所有的标签逻辑,包括输出、迭代、修改标签体内容等。在doTag方法中可以抛出javax.servlet.jsp.SkipPageException异常,用于通知WEB容器不再执行JSP页面中位于结束标记后面的内容,这等效于在传统标签的doEndTag方法中返回Tag.SKIP_PAGE常量的情况。
接下来会用simpleTag来实现上篇的功能 小个小Demo
- 控制标签体是否执行
public class Demo1 extends SimpleTagSupport {
@Override
public void doTag() throws JspException, IOException {
//得到标签体
JspFragment jf=this.getJspBody();
//得到 pageContext 从而得到流 进而进行操作
PageContext pageContext = (PageContext) this.getJspContext();
// jf.invoke(pageContext.getOut()); // 将流输入给浏览器
//上面的操作 可以简单的写成 意思就是写给浏览器 数据
//jf.invoke(null);
//如果不输出 标签体给 浏览器 则 注释掉 jf.invoke(null); 表示不给浏览器输出 流 则不显示 标签体
}
}
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib uri="/simpleTld" prefix="simpleTld"%>
用 simpleTag 控制界面中的 jsp代码是否执行
看看执行吗
- 控制标签体 执行次数
/**
* 控制 标签体执行 10次
*
*/
public class Demo2 extends SimpleTagSupport {
@Override
public void doTag() throws JspException, IOException {
JspFragment jf = this.getJspBody();
for(int i=0;i<10;i++){
jf.invoke(null);
}
}
}
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib uri="/simpleTld" prefix="simpleTld"%>
用 simpleTag 控制界面中的 jsp代码执行几遍
看看执行几遍
- 改变标签体的内容
public class Demo3 extends SimpleTagSupport{
@Override
public void doTag() throws JspException, IOException {
JspFragment jf = this.getJspBody();
StringWriter sw = new StringWriter();
jf.invoke(sw); //将数据写到了 StringWriter 流中
String content = sw.getBuffer().toString(); //得到写入的内容
content = content.toUpperCase(); //将内容进行改变
PageContext pageContent = (PageContext) this.getJspContext();//重新写给 流 中
pageContent.getOut().write(content);
}
}
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib uri="/simpleTld" prefix="simpleTld"%>
用 simpleTag 控制界面中的 标签体中的数据
xxxxxxxx
- 控制便签余下的jsp不执行
public class Demo4 extends SimpleTagSupport{
@Override
public void doTag() throws JspException, IOException {
throw new SkipPageException();
}
}
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib uri="/simpleTld" prefix="simpleTld"%>
用 simpleTag 控制标签余下的jsp是否执行
看看上面的执行呢
xxxxxxxx
看看 下面的jsp是否执行呢?
- 通过属性控制标签体的执行次数
public class Demo5 extends SimpleTagSupport {
private int count;//次数
public void setCount(int count) {
this.count = count;
}
@Override
public void doTag() throws JspException, IOException {
for (int i = 0; i < count; i++) {
this.getJspBody().invoke(null);
}
}
}
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib uri="/simpleTld" prefix="simpleTld"%>
用 simpleTag 动态控制执行标签体的次数
看看是否执行了5次
- 自定义标签属性
public class Demo6 extends SimpleTagSupport{
private Date date;
public void setDate(Date date) {
this.date = date;
}
@Override
public void doTag() throws JspException, IOException {
System.out.println(date);
}
}
<%@page import="java.util.Date"%>
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib uri="/simpleTld" prefix="simpleTld"%>
用 simpleTag 标签属性
<%
Date date=new Date();
request.setAttribute("date", date);
%>
最后贴出 .tld文件
A tag library exercising SimpleTag handlers.
1.0
SimpleTagLibrary
/simpleTld
demo1
jeno.com.sample.tld.Demo1
scriptless
demo2
jeno.com.sample.tld.Demo2
scriptless
demo3
jeno.com.sample.tld.Demo3
scriptless
demo4
jeno.com.sample.tld.Demo4
scriptless
demo5
jeno.com.sample.tld.Demo5
scriptless
count
true
true
demo6
jeno.com.sample.tld.Demo6
scriptless
date
true
true