jsp自定义标签
程序员文章站
2022-05-30 21:25:23
...
自定义标签的流程步骤图
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>
如果大家还有问题的话可以到我的资源库下载源码学习。点击下载
----------------如果大家喜欢我的博客,可以点击左上角的关注哦。
上一篇: Android 图片裁剪功能实现详解(类似QQ自定义头像裁剪)
下一篇: 搜索/模拟好题——终焉花海