1.标签语言特点
<开始标签 属性=“属性值”>标签体</结束标签>
2. 自定义标签的开发及使用步骤
2.1 创建一个标签助手类(继承BodyTagSupport)
标签属性必须助手类的属性对应、且要提供对应get/set方法
rtexprvalue
2.2 创建标签库描述文件(tld),添加自定义标签的配置
2.3 在JSP通过taglib指令导入标签库,并通过指定后缀
访问自定义标签
代码如下:
2.1
import javax.servlet.jsp.tagext.BodyTagSupport;
/**
* 凡是继承了BodyTagSupport就是一个标签助手类
* 1.默认情况,如果jsp上面有标签体name三个方法都执行
* 如果没有标签体,那么doAfterBody方法不会执行
*
* 2.人为改变默认设置:
* a.此时jsp上有标签体,人为将doStartTag的返回值改为SKIP_BODY,
* 那么doAfterBody也不执行并且jsp页面主体内容也不显示
*
* b.如果改变doAfterBody的默认返回值为EVAL_BODY_AGAIN,那么doAfterBody方法会反复执行
* @author zrh
*
*
* 1. 标签语言特点<开始标签 属性="属性值">标签体</结束标签>
*
*/
public class DeomTag extends BodyTagSupport {
private static final long serialVersionUID = -7972922044210794216L;
private String test;
public String getTest() {
return test;
}
public void setTest(String test) {
this.test = test;
}
@Override
public int doStartTag() throws JspException {
System.out.println("~~~~~~~~~~~~~~~~~doStartTag!~~~~~~~~~~~~");
// return super.doStartTag();
// return SKIP_BODY;//跳过主体
return EVAL_BODY_INCLUDE;
}
@Override
public int doEndTag() throws JspException {
System.out.println("~~~~~~~~~~~~~~~~~doEndTag!~~~~~~~~~~~~");
return super.doEndTag();
}
@Override
public int doAfterBody() throws JspException {
System.out.println("~~~~~~~~~~~~~~~~~doAfterBody!~~~~~~~~~~~~");
// return super.doAfterBody();
return EVAL_BODY_AGAIN;
}
}
SKIP_BODY:跳过主体
EVAL_BODY_INCLUDE:计算标签主体内容并[输出]
EVAL_BODY_BUFFERED:计算标签主体内容并[缓存]
EVAL_PAGE:计算页面的后续部分
SKIP_PAGE:跳过页面的后续部分
EVAL_BODY_AGAIN:再计算主体一次
2.2
<?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>zking 1.1 core library</description>
<display-name>zking core</display-name>
<tlib-version>1.1</tlib-version>
<short-name>c</short-name>
<uri>/zking</uri>
<tag>
<!-- 标签库中的标签名 -->
<name>demo</name>
<!-- 标签对应的助手类的全路径名 -->
<tag-class>com.zking.jsp.day01.DeomTag</tag-class>
<body-content>JSP</body-content>
<attribute>
<!-- 属性名 -->
<name>test</name>
<!-- 属性值是否必填 -->
<required>false</required>
<!-- 是否支持表达式 -->
<rtexprvalue>false</rtexprvalue>
</attribute>
</tag>
</taglib>
注意:tld文件必须保存到WEB-INF目录或其子目录
下面我们看一下生命周期图
3. c:out标签
3.1 c:out标签是什么
<c:out>标签用来显示一个表达式的结果,与<%= %>作用相似,它们的区别就是<c:out>标签可以直接通过"."操作符来访问属性。
语法格式
<c:out value="" default="" escapeXml="<true|false>"/>
escapeXml若为true则未使用转义字符,若为false则使用转义字符
示例如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
<head>
<title>c:out 标签实例</title>
</head>
<body>
<h1><c:out> 实例</h1>
<c:out value="<要显示的数据对象(未使用转义字符)>" escapeXml="true" default="默认值"></c:out><br/>
<c:out value="<要显示的数据对象(使用转义字符)>" escapeXml="false" default="默认值"></c:out><br/>
<c:out value="${null}" escapeXml="false">使用的表达式结果为null,则输出该默认值</c:out><br/>
</body>
</html>
输出结果为:
4 . c:foreach标签
c:foreac标签封装了Java中的for,while,do-while循环,它迭代一个集合中的对象
forEach 语法格式
<object>"
begin="<int>"
end="<int>"
step="<int>"
var="<string>"
varStatus="<string>">
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
<head>
<title>c:forEach 标签实例</title>
</head>
<body>
<c:forEach var="i" begin="1" end="6">
Item <c:out value="${i}"/><p>
</c:forEach>
</body>
</html>
输出结果为:
大家还想了解哪些标签?请看下方,自己去了解吧
https://www.runoob.com/jsp/jsp-jstl.html