简单标签

来源:互联网 发布:八戒影院软件 编辑:程序博客网 时间:2024/05/19 13:20
<!--jsp  
package com.hbsi.web.example;import java.io.IOException;import javax.servlet.jsp.JspException;import javax.servlet.jsp.tagext.SimpleTagSupport;public class IfDemo1 extends SimpleTagSupport{private boolean test;public void setTest(boolean test) {this.test = test;}public void doTag() throws JspException, IOException {//条件成立就执行if(test){//获取标签体的内容,并输出this.getJspBody().invoke(null);}}}

开发<c:if>标签-->
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%@ taglib uri="http://www.csdn.com" prefix="c"%><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html>  <head>    <base href="<%=basePath%>">        <title>My JSP 'demo1.jsp' starting page</title>    <meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0">    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">-->  </head>    <body>  <c:if test="${user==null}">  张三  </c:if>      </body></html>//处理jsp类
package com.hbsi.web.example;import java.io.IOException;import javax.servlet.jsp.JspException;import javax.servlet.jsp.tagext.SimpleTagSupport;public class IfDemo1 extends SimpleTagSupport{private boolean test;public void setTest(boolean test) {this.test = test;}public void doTag() throws JspException, IOException {//条件成立就执行if(test){//获取标签体的内容,并输出this.getJspBody().invoke(null);}}}

 

 

<!--  

开发<c:if><c:else>标签

 -->

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%@ taglib uri="http://www.csdn.com" prefix="c"%><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html>  <head>    <base href="<%=basePath%>">        <title>My JSP 'demo2.jsp' starting page</title>    <meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0">    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">-->  </head>    <body>    <c:choose><c:when test="<%=true %>">aaa</c:when><c:otherwise>bbbb</c:otherwise></c:choose>  </body></html>


 

 

package com.hbsi.web.example;import java.io.IOException;import javax.servlet.jsp.JspException;import javax.servlet.jsp.tagext.SimpleTagSupport;public class IfElseDemo2 extends SimpleTagSupport {//设置一个标志,来让子标签判断执行哪个?private boolean isOK;public boolean isOK() {return isOK;}public void setOk(boolean isOk) {this.isOK = isOk;}@Overridepublic void doTag() throws JspException, IOException {this.getJspBody().invoke(null);//父标签}}


 

package com.hbsi.web.example;import java.io.IOException;import javax.servlet.jsp.JspException;import javax.servlet.jsp.tagext.SimpleTagSupport;public class WhenDemo1 extends SimpleTagSupport {private boolean test;public void setTest(boolean test) {this.test = test;}@Overridepublic void doTag() throws JspException, IOException {IfElseDemo2 parent=(IfElseDemo2) this.getParent();if(test && !parent.isOK()){this.getJspBody().invoke(null);parent.setOk(true);}}}


 

package com.hbsi.web.example;import java.io.IOException;import javax.servlet.jsp.JspException;import javax.servlet.jsp.tagext.SimpleTagSupport;public class OtherWiseDemo extends SimpleTagSupport {@Overridepublic void doTag() throws JspException, IOException {IfElseDemo2 parent=(IfElseDemo2) this.getParent();if(!parent.isOK()){this.getJspBody().invoke(null);parent.setOk(true);}}}


<!-- –

开发迭代标签

-->

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%@ taglib uri="http://www.csdn.com" prefix="c"%><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html>  <head>    <base href="<%=basePath%>">        <title>My JSP 'demo3.jsp' starting page</title>    <meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0">    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">-->  </head>    <body>  <%  List list=new ArrayList();  list.add("aa");  list.add("bb");  list.add("cc");  list.add("dd");    request.setAttribute("list",list);   %>    <c:forEach var="str" items="${list}">${str}<br></c:forEach>  </body></html>


 

package com.hbsi.web.example;import java.io.IOException;import java.util.Iterator;import java.util.List;import javax.servlet.jsp.JspException;import javax.servlet.jsp.tagext.SimpleTagSupport;public class ForEachDemo extends SimpleTagSupport {private String var;private List items;public void setVar(String var) {this.var = var;}public void setItems(List items) {this.items = items;}public void doTag() throws JspException, IOException {Iterator it=items.iterator();while(it.hasNext()){Object obj=it.next();this.getJspContext().setAttribute(var,obj);this.getJspBody().invoke(null);}}}

 

//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">    <description>A tag library exercising SimpleTag handlers.</description>    <tlib-version>1.0</tlib-version>    <short-name>c</short-name>    <uri>http://www.csdn.com</uri>        <tag> <name>if</name><tag-class>com.hbsi.web.example.IfDemo1</tag-class><body-content>scriptless</body-content><attribute><name>test</name><required>true</required><rtexprvalue>true</rtexprvalue></attribute>    </tag>             <tag> <name>choose</name><tag-class>com.hbsi.web.example.IfElseDemo2</tag-class><body-content>scriptless</body-content>    </tag>         <tag> <name>when</name><tag-class>com.hbsi.web.example.WhenDemo1</tag-class><body-content>scriptless</body-content><attribute><name>test</name><required>true</required><rtexprvalue>true</rtexprvalue></attribute>    </tag>         <tag> <name>otherwise</name><tag-class>com.hbsi.web.example.OtherWiseDemo</tag-class><body-content>scriptless</body-content>    </tag>         <tag> <name>forEach</name><tag-class>com.hbsi.web.example.ForEachDemo</tag-class><body-content>scriptless</body-content><attribute><name>var</name><required>true</required><rtexprvalue>true</rtexprvalue></attribute> <attribute><name>items</name><required>true</required><rtexprvalue>true</rtexprvalue></attribute>    </tag> </taglib>


 

 

 


自定义标签--------简单标签

由于传统标签使用三个标签接口来完成不同的功能,显得过于繁琐,不利于标签技术的推广, SUN公司为降低标签技术的学习难度,在JSP 2.0中定义了一个更为简单、便于编写和调用的SimpleTag接口来实现标签的功能。实现SimpleTag接口的标签通常称为简单标签。简单标签共定义了5个方法:

setJspContext 方法

setParent 和getParent 方法

setJspBody 方法

doTag 方法

一、SimpleTag方法介绍

1、setJspContext方法

用于把JSP页面的pageContext对象传递给标签处理器对象 

2、setParent方法

用于把父标签处理器对象传递给当前标签处理器对象 

3、getParent方法

用于获得当前标签的父标签处理器对象 

4、setJspBody方法

用于把代表标签体的JspFragment对象传递给标签处理器对象 

5、doTag方法

用于完成所有的标签逻辑,包括输出、迭代、修改标签体内容等。在doTag方法中可以抛出javax.servlet.jsp.SkipPageException异常,用于通知WEB容器不再执行JSP页面中位于结束标记后面的内容,这等效于在传统标签的doEndTag方法中返回Tag.SKIP_PAGE常量的情况。 

二、SimpleTag接口方法的执行顺序

1、当web容器开始执行标签时,会调用如下方法完成标签的初始化

(1)WEB容器调用标签处理器对象的setJspContext方法,将代表JSP页面的pageContext对象传递给标签处理器对象。

(2)WEB容器调用标签处理器对象的setParent方法,将父标签处理器对象传递给这个标签处理器对象。注意,只有在标签存在父标签的情况下,WEB容器才会调用这个方法。

(3)如果调用标签时设置了属性,容器将调用每个属性对应的setter方法把属性值传递给标签处理器对象。如果标签的属性值是EL表达式或脚本表达式,则WEB容器首先计算表达式的值,然后把值传递给标签处理器对象。

(4)如果简单标签有标签体,容器将调用setJspBody方法把代表标签体的JspFragment对象传递进来。

2、执行标签时:

容器调用标签处理器的doTag()方法,开发人员在方法体内通过操作JspFragment对象,就可以实现是否执行、迭代、修改标签体的目的。

三、JspFragment

javax.servlet.jsp.tagext.JspFragment类是在JSP2.0中定义的,它的实例对象代表JSP页面中的一段符合JSP语法规范的JSP片段,这段JSP片段中不能包含JSP脚本元素。

WEB容器在处理简单标签的标签体时,会把标签体内容用一个JspFragment对象表示,并调用标签处理器对象的setJspBody方法把JspFragment对象传递给标签处理器对象。JspFragment类中只定义了两个方法,如下所示:

getJspContext 方法

用于返回代表调用页面的JspContext对象.

public abstract void invoke(java.io.Writer out) 

用于执行JspFragment对象所代表的JSP代码片段

参数out用于指定将JspFragment对象的执行结果写入到哪个输出流对象中,如果传递给参数out的值为null,则将执行结果写入到JspContext.getOut()方法返回的输出流对象中。(简而言之,可以理解为写给浏览器)

四、invoke方法详解  

JspFragment.invoke方法是JspFragment最重要的方法,利用这个方法可以控制是否执行和输出标签体的内容、是否迭代执行标签体的内容或对标签体的执行结果进行修改后再输出。例如:

 在标签处理器中如果没有调用JspFragment.invoke 方法,其结果就相当于忽略标签体内容;  在标签处理器中重复调用JspFragment.invoke 方法,则标签体内容将会被重复执行;  若想在标签处理器中修改标签体内容,只需在调用invoke 方法时指定一个可取出结果数据的输出流对象(例如StringWriter ),让标签体的执行结果输出到该输出流对象中,然后从该输出流对象中取出数据进行修改后再输出到目标设备,即可达到修改标签体的目的。

五、开发带属性的标签

自定义标签可以定义一个或多个属性,这样,在JSP页面中应用自定义标签时就可以设置这些属性的值,通过这些属性为标签处理器传递参数信息,从而提高标签的灵活性和复用性。

要想让一个自定义标签具有属性,通常需要完成两个任务:

在标签处理器中编写每个属性对应的setter方法

TLD文件中描术标签的属性

 为自定义标签定义属性时,每个属性都必须按照JavaBean 的属性命名方式,在标签处理器中定义属性名对应的setter 方法,用来接收JSP 页面调用自定义标签时传递进来的属性值。  例如属性url ,在标签处理器类中就要定义相应的setUrl(String url) 方法。  在标签处理器中定义相应的set 方法后,JSP 引擎在解析执行开始标签前,也就是调用doStartTag 方法前,会调用set 属性方法,为标签设置属性。

六、TLD中描述标签属性 attribute

tag>元素的<attribute>子元素用于描述自定义

标签的一个属性,自定义标签所具有的每个属性

都要对应一个<attribute>元素 。

<attribute>

<description>description</description>

<name>aaaa</name>

<required>true</required>

<rtexprvalue>true</rtexprvalue>

<type>ObjectType</type>

</attribute>

 

原创粉丝点击