jsp自定义标签

自定义标签的流程步骤

1.自定义标签的开发步骤

1.1创建标签助手类

   继承BodyTagSupport并重写相关方法即可

/**
 * 标签助手类(if标签)
 * @author king
 *
 */
public class IfTag extends BodyTagSupport{
private boolean test;

public IfTag() {
super();
}

public boolean isTest() {
return test;
}
public void setTest(boolean test) {
this.test = test;
}

@Override
public int doStartTag() throws JspException {
if(this.test){//如果为true
return EVAL_BODY_INCLUDE;
}else{
return SKIP_BODY;
}
}
}

1.2创建标签库描述对象

后缀名:.tld     保存位置:WEB-INF    定义自定义标签

1.3自定义标签的使用

1.3.1 taglib指令导入标签库
    1.3.2 通过前缀访问自定义标签

<!DOCTYPE taglib
  PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN"
   "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd">
<!-- 标签库描述符 -->
<taglib xmlns="http://java.sun.com/JSP/TagLibraryDescriptor">
<tlib-version>1.0</tlib-version>
<jsp-version>1.2</jsp-version>
<short-name>Simple Tags</short-name>
<uri>/veryedu</uri>

<tag>
<!-- 标签名 -->
<name>if</name>
<!-- 标签助手类 -->
<tag-class>tags.ui.IfTag</tag-class>
<!-- 标签的内容类型:empty表示空标签,jsp表示可以为任何合法的JSP元素 -->
<body-content>jsp</body-content>
<attribute>
<name>test</name>
<!-- 属性能为空吗 -->
<required>true</required>
<!-- 是否接受表达式作为值 -->
<rtexprvalue>true</rtexprvalue>
</attribute> 
</tag>
</taglib>

2.自定义标签的生命周期

    2.1 doStartTag返回的三种信号
      SKIP_BODY:跳过主体
      EVAL_BODY_INCLUDE:计算主体并包含到页面
      EVAL_BODY_BUFFERED:计算主体并缓存(不会包含到页面) BodyContent

    2.2 doEndTag返回的二种信号
      SKIP_PAGE:跳过页面的剩余内容
      EVAL_PAGE:执行页面的剩余内容

    2.3 doAfterBody返回的两种信号

        SKIP_BODY:跳过主体  

        EVAL_BODY_AGAIN:再一次计算主体并包含到页面

     2.4 setBodyContent
          doInitBody

jsp页面:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@taglib prefix="v" uri="/veryedu"%>
<%
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 'index.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> 
<P>
<v:if test="${1==2 }">
1==2不存在的
</v:if>
</P>
<P>
<v:if test="${ 1!=2 }">
1!=2存在的
</v:if>
</P>
  </body>
</html>

如果大家还有问题的话可以到我的资源库下载源码学习。点击下载

 

----------------如果大家喜欢我的博客,可以点击左上角的关注哦。
 

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值