第二十五天(简单标签)

自定义标签

1.创建一个标签处理器类:实现SimpleTag接口(或者直接继承SimpleTagSupport)

2.再WEB=INF文件夹下新建一个 .tld(标签库描述文件) 为扩展名的 xml 文件,并考入固定的部分,并对description,display-name,tlib-version,short-name,uri 修改

3.在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>MyTag 1.0 core library</description>
  <display-name>MyTag core</display-name>
  <tlib-version>1.0</tlib-version>
  <short-name>baidu</short-name>
  <uri>http://www.baidu.com/mytag/core</uri>
  
  <tag>
  	<name>hello</name>
  	<tag-class>com.ohh.suc.HelloSimpleTag</tag-class>
  	<body-content>empty</body-content>
  </tag>
  
</taglib>

4.在JSP页面上使用自定义标签

①使用taglib指定导入标签库描述文件:<%@taglib uri="http://www.baidu.com/mytag/core" prefix="baidu" %>

②使用自定义的标签:<baidu:hello/>



setJspContext:一定会被 JSP 引擎所调用,先于 doTag,把代表 JSP 引擎的pageContext传给标签处理器类:

	private PageContext pageContext;
	public void setJspContext(JspContext arg0) {
		this.pageContext = (PageContext) arg0;
	}



带属性的自定义标签

1.先在标签处理器类中定义 setter 方法 建议把所有的属性都设为String类型

	private String value;
	private String count;
	
	public void setValue(String value) {
		this.value = value;
	}

	public void setCount(String count) {
		this.count = count;
	}


2.在tld描述文件中来描述属性:

  	<attribute>
  		<!-- 属性名 -->
  		<name>value</name>
  		<!-- 该属性是否是必须的 -->
  		<required>true</required>
  		<!-- 该属性是否可以接收运行时表达式的动态值 -->
  		<rtexprvalue>true</rtexprvalue>
  	</attribute>

3.在页面中使用属性,属性名同tld文件中定义的名字



通常情况下开发简单标签直接继承SimpleTagSupport就可以了,可以直接调用其对应的 getter 方法得到对应的API



带标签体的自定义标签

1.若一个标签有标签体

    在自定义标签的标签处理器中使用JspFragment对象封装标签体信息

2.若配置了标签含有标签体,则JSP引擎会调用setJspBody()方法把JspFragment传递给标签处理器类

    在SimpleTagSupport中还定义了一个getJspBody()方法,用于返回JspFragment对象

3.JspFragment的invoke(Writer)方法:把标签体内容从Writer中输出,若为null则等同于invoke(getJspContext.getOut()),即直接把标签体内容输出到页面上

    有时,可以借助于StringWriter,可以在标签处理器类中先得到标签体的内容:

		JspFragment bodyContent = getJspBody();
		StringWriter sw = new StringWriter();
		bodyContent.invoke(sw);

4.在tld文件中,使用 body-content 节点来描述标签体的类型,大部分情况下取值为scriptless

    empty:没有标签体

    scriptless*:标签体可以包含el表达式和JSP动作元素,但不能包含JSP脚本元素 不能写<%= ...%>

    tagdependent:表示标签体交由标签本身去解析处理,若指定tegdependent,在标签体中的所有代码都会原封不动的交给标签处理器,EL表达式不会执行



开发有父标签的标签

1.父标签无法获取子标签的引用,父标签仅把子标签作为标签体来使用

2.子标签可以通过getParent()方法来获取父标签的引用(需继承SimpleTagSupport或自实现SimpleTag接口的该方法)

若子标签的确有父标签,JSP引擎会吧代表父标签的引用通过setParent(JspTag parent)赋给标签处理器

3.注意 父标签的类型是JspTag类,该接口是一个空接口,是来统一SimpleTag和Tag的,实际使用需要进行类型的强制转换

4.在tld配置文件中,无需为父标签有额外的配置,但子标签是以标签体的形式存在的,所以父标签的<body-content>需设置为scriptless


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值