第9章 简单标签
9.1 简单标签知识
在Jsp2.0中定义SimpleTag
接口用于替换传统的标签开发的接口,它只有一个方法doTag()
用于取代传统的doStartTag()、doEndTag()、doAfterBody()
等方法。
1、 JSP引擎调用标签处理器对象的setJspContext(),将JSP页面的pageContext()对象传递给标签处理器对象。
2、 JSP引擎调用setParent(),将父标签处理器对象传递给标签处理器对象。
3、 如果调用标签设置属性,容器将每个属性对应的setter()方法把属性值传递给标签处理器对象。
4、 如果有标签体,容器将标签体封装为JspFragment对象,然后调用setJspBody()将JspFragment对象传递给标签处理器对象。
5、 调用doTag()方法执行标签逻辑。
9.1.1 SimpleTag接口
SimpleTag接口定义方法:
1、 setJspContext()
public void setJspContext(JspContext context);
JSP页面的pageContext对象传递给标签处理器对象。
2、 setParent()
public void setParent(JspTag parent);
把父标签处理器对象传递给当前标签处理器对象。
3、 getParent()
public JspTag getParent();
获取当前父标签处理器对象。
4、 setJspBody()
public void setJspBody(JspFragment jspBody);
把代表标签体的JspFragment对象传递给标签处理器对象。
5、 doTag()
public void doTag();
用于完成标签处理逻辑。
9.1.2 JspFragment类
JSP引擎处理标签体内容时会把标签体内容用一个JspFragement对象表示,并调用标签体处理器对象的setJspBody()把JspFragement对象传递给标签处理器对象,标签开发者根据需要调用JspFragement对象的方法,决定是否执行和输出标签体。
1、 getJspContext()
public abstract JspContext getJspContext();
用于返回调用页面的JspContext对象。
2、 invoke()
public abstract void invoke(Writer out);
用于执行JspFragment对象代表的JSP代码片段。
9.1.3 SimpleTagSupport类
SimpleTagSupport类是SimpleTag接口的实现。
9.2 简单标签实例
public class SimpleTagDemo extends SimpleTagSupport {
private String username;
public void setUsername(String username) {
this.username = username;
}
@Override
public void doTag() throws JspException, IOException {
if ("wangtong".equals(username)) {
JspFragment fragment = this.getJspBody();
fragment.invoke(null);
} else {
getJspContext().getOut().write("用户名不正确");
throw new SkipPageException();
}
}}
<tag>
<name>simpleTag</name>
<tag-class>tag.simpletag.SimpleTagDemo</tag-class>
<body-content>scriptless</body-content>
<attribute>
<name>username</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
<wangtong:simpleTag username="wangtong">
username
</wangtong:simpleTag>
9.3 迭代数组
public class SimpleIterateTag extends SimpleTagSupport {
private String name;
private String items[];
public void setName(String name) {
this.name = name;
}
public void setItems(String[] items) {
this.items = items;
}
@Override
public void doTag() throws JspException, IOException {
for (String i : items) {
getJspContext().setAttribute(name, i);
getJspBody().invoke(null);
}}}
<tag>
<name>simpleIterateTag</name>
<tag-class>tag.simpletag.SimpleIterateTag</tag-class>
<body-content>scriptless</body-content>
<attribute>
<name>name</name>
<required>true</required>
</attribute>
<attribute>
<name>items</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
<%
String[] books = { "book1", "book2", "book3" };
%>
<wangtong:simpleIterateTag items="<%=books%>" name="bookname">
${bookname}
</wangtong:simpleIterateTag>
9.4 修改标签体内容
public class ReadFileTag extends SimpleTagSupport {
private String src;
public void setSrc(String src) {
this.src = src;
}
@Override
public void doTag() throws JspException, IOException {
InputStream in;
BufferedReader br;
try {
in = ((PageContext) getJspContext()).getServletContext()
.getResourceAsStream(src);
br = new BufferedReader(new InputStreamReader(in));
String line = br.readLine();
while (line != null) {
this.getJspContext().getOut().write("line" + "\r\n");
line = br.readLine();
}
br.close();
} catch (Exception e) {
e.getMessage();
}}}
public class HtmlFilterTag extends SimpleTagSupport {
@Override
public void doTag() throws JspException, IOException {
JspFragment fragment = this.getJspBody();
StringWriter writer = new StringWriter();
fragment.invoke(writer);
String newBody = filter(writer.toString());
this.getJspContext().getOut().write(newBody);
}
private String filter(String message) {
if (message == null) {
return null;
}
char content[] = new char[message.length()];
message.getChars(0, message.length(), content, 0);
StringBuffer result = new StringBuffer(content.length + 50);
for (int i = 0; i < content.length; i++) {
switch (content[i]) {
case '<':
result.append("<");
break;
case '>':
result.append(">");
break;
case '&':
result.append("&");
break;
case '"':
result.append(""");
break;
default:
result.append(content[i]);
}
}
return result.toString();
}}
<tag>
<name>simpleHtmlFilter</name>
<tag-class>tag.simpletag.ReadFileTag</tag-class>
<body-content>scriptless</body-content>
</tag>
<tag>
<name>simpleReadFile</name>
<tag-class>tag.simpletag.HtmlFilterTag</tag-class>
<body-content>empty</body-content>
<attribute>
<name>src</name>
<required>true</required>
</attribute>
</tag>
<wangtong:simpleHtmlFilter>
<wangtong:readfile src="/tag.jsp" />
</wangtong:simpleHtmlFilter>
分享到:
相关推荐
"jsp简单标签的使用"这个主题主要涵盖JSP中的内置标签和自定义标签的使用方法。 首先,JSP内置标签是预定义的一组标签,它们提供了与Servlet生命周期相关的功能,例如控制流程、数据处理等。以下是一些常见的内置...
JSP简单标签是JSP自定义标签的一种形式,它允许开发者创建自定义的行为,以替代硬编码的Java脚本。本教程将深入探讨JSP简单标签的概念、使用方式以及其在实际开发中的应用。 一、JSP简单标签概述 JSP简单标签是...
**JSP简单标签编程详解** 在Java服务器页面(JSP)技术中,标签库是实现业务逻辑和表现层分离的重要工具。本篇文章将深入探讨JSP中的简单标签编程,帮助开发者更好地理解和应用这一实用技术。 ### 1. JSP标签概述 ...
JSP简单标签库编程很好的 帮助大大的有,请大家多指点
JSP简单标签.part1.rar
JSP简单标签.part2.rar
JSP简单标签 简单标签是自定义标签的一种特殊形式,它们没有开始和结束标签,只有一个`doTag()`方法来执行标签的逻辑。相比完整的自定义标签,简单标签更易于实现和使用,因为它们不需要处理开始和结束标签的逻辑...
总结来说,"简单JSP标签实现迭代"这个实例涉及了JSP自定义标签的创建和使用,包括TLD文件的配置、标签处理类的编写以及标签文件的设计。通过这种方式,我们可以更好地组织和管理代码,提高开发效率,并使得JSP页面...
本实例将深入探讨如何实现一个简单的JSP自定义标签。 首先,自定义标签的实现主要依赖于两个核心概念:Tag接口和TagSupport类。`Tag`接口定义了自定义标签必须实现的方法,如`doStartTag()`和`doEndTag()`,它们...
1.1 使用简单标签机制 JSP自定义标签提供了类似HTML标签的语法结构,通过自定义标签,开发者可以封装复杂的Java代码,使得页面更加简洁易读。简单标签机制无需提供标签体,仅通过标签属性传递参数。 1.2 使用标签...
1. **简单标签**: 不需要遍历或修改JSP页面的内容,如显示数据。 2. **迭代标签**: 遍历集合并多次输出内容,如foreach标签。 3. **身体标签**: 包含一个或多个动态生成的JSP片段作为其内容,如。 **自定义标签的...
以下是一个简单的分页标签实现思路: 1. **分页参数**:在自定义标签中接收总记录数、每页显示条数、当前页码等参数。 2. **计算页数**:根据总记录数和每页显示条数计算总页数。 3. **生成链接**:为每一页生成...
- **简单标签(Simple Tag)**:简单标签无需实现完整的生命周期方法,适用于处理简单的逻辑。 - **全功能标签(Full-Body Tag)**:全功能标签需要实现整个生命周期,包括doStartTag、doEndTag等方法,可以处理复杂的...
### jsp自定义简单标签:hellotag 在JavaServer Pages (JSP) 技术中,自定义标签是扩展其功能的一种强大方法。通过创建自定义标签,开发者可以封装复杂的逻辑并将其重用到多个页面中,从而提高代码的可读性和可维护...
**JSP标准标签库(JSTL)**是Java服务器页面(JSP)技术的一个重要扩展,它提供了一组预定义的标签,用于简化JSP页面的开发和维护。JSTL的主要目标是减少在JSP中使用脚本元素,从而提高代码的可读性和可维护性。 ...