本章导读
主要内容
- Tag文件结构
- Tag标记
- Tag文件的常用命令
难点 - Tag文件中的attribute指令
- Tag文件中的variable指令
3.1 Tag文件
3.1.1 Tag文件的结构
扩展名为XX.tag的文本文件,包含HTML标记符,特殊的指令标记,成员变量和方法的定义,Java程序片和Java表达式
3.1.2. Tag文件的保存
- Tag文件所在目录
建立以下目录结构
Tomcat的web服务目录\WEB-INF\tags
注意WEB-NF大写
- Tag文件的编码
编码格式为utf-8
<%@ tag pageEncoding =“utf-8” % %>
3.2 Tag标记
3.2.1 Tag标记与Tag文件
Tag标记的名字和Tag文件的名字一致,也就是我们编写一个Tag文件并保存到特定的目录(前面讲了),也就给出了一个Tag标记,该文件的格式为:
<Tag文件的名字>
或
<Tag文件的名字>其他内容</Tag文件的名字>
3.2.2 Tag标记的使用
JSP页面调用Tag文件–>先使用taglib指令标记引入标记库->使用Tag标记调用Tag文件,格式如下:
<%@ taglib tagdir=“标记库的位置” prefix=“前缀”>
例如;
<%@ taglib tagdir=“WEB-INF/tags” prefix=“computer”>
其中的前缀是用户定义的,便于区分标记文件
< comperter:oddNumberSum>
例:
<%@ page contentType = "text/html" %>
<%@ page pageEncoding = "utf-8" %>
<%@ taglib tagdir = "/WEB-INF/tags" prefix = "computer"%>
<HTML><body bgcolor = cyan>
<h1>调用Tag文件计算100内奇数和:</h1>
<computer:oddNumberSum /> <%-- 使用Tag标记 --%>
</body></HTML>
Tag文件
3.2.3 Tag标记的运行原理
Tomcat将Tag文件转译成Java文件->编译Java文件成字节码文件->执行
3.3 Tag文件中的常用指令
3.3.1 tag指令
指定某些属性的值
<%@ tag属性1="属性值"属性2="属性值"属性3=“属性值”…%>
或
<%@ tag属性1=“属性值”>
<%@ tag属性2=“属性值”>
<%@ tag属性3=“属性值”>
- language属性
目前只能取值Java,默认值就是Java,无需自己设置
- import属性
引入包名
- pageEncoding属性
指定编码格式,为防止出现乱码格式,需设置为UTF-8
3.3.2 include指令
与第二章的JSP文件中的使用方法类似
3.3.3 attribute指令
通过attribute指令让使用它的JSP页面向该Tag文件传递需要的数据,格式如下:
<%@ attribute name=“对象的名字” required=“true”|“false” type=“对象的类型”%>
例子:
<%@ attribute name="result" required="true" type="java.lang.Double"%>
相当于Tag文件无需创建对象result,只需等待JSP页面将一个double型的对象的引用传递给result
- 其中的name属性是必需的,type在指定类型时,必须要有包名,若没有指定,默认为java.lang.String类型,required默认为false
具体情况可以看下面例子:
使用Tag标记调用triangle.tag文件,并向triangle.tag传递三角形三边长度
triangle.tag
<%@ tag pageEncoding="utf-8" %>
<%@ attribute name="sideA" required="true" %>
<%@ attribute name="sideB" required="true" %>
<%@ attribute name="sideC" required="true" %>
<%! public String getArea(double a,double b,double c) {
if(a+b>c&&a+c>b&&c+b>a) {
double p=(a+b+c)/2.0;
double area=Math.sqrt(p*(p-a)*(p-b)*(p-c)) ;
String result = String.format("%.2f",area);
return "<br>三角形面积(小数点保留2位):"+result;
}
else
return("<br>"+a+","+b+","+c+"不能构成一个三角形,无法计算面积");
}
%>
<% out.println("<BR>三边:"+sideA+","+sideB+","+sideC);
double a=Double.parseDouble(sideA);
double b=Double.parseDouble(sideB);
double c=Double.parseDouble(sideC);
out.println(getArea(a,b,c));
%>
example3_2.jsp
<%@ page contentType="text/html" %>
<%@ page pageEncoding = "utf-8" %>
<%@ taglib tagdir="/WEB-INF/tags/example2" prefix="getTriangleArea"%>
<HTML><body bgcolor = yellow >
<p style="font-family:宋体;font-size:36;color:blue">
<%-- 使用Tag标记: --%>
<getTriangleArea:triangle sideA="15" sideB="16" sideC="20"/>
</p>
</body></HTML>
3.3.4 variable指令
上文的attribute标记是向Tag文件传递数据,现在这个variable标记可以将Tag文件的对象返回给调用该Tag文件的JSP页面
- variable指令的格式
<%@ variable name-given=“对象名” variable-class=“对象的类型” scope=“有效范围”%>
- name-given:Tag文件返回给JSP页面的对象(由字母,下划线,美元符号和数字组成)
- variable-class:返回的对象的类型,必须要完整包名,默认为java.lang.String类型
- scope:
- List item:
AT_BEGIN:一开始使用Tag标记,就得到了返回的对象
NESTED:只可以在Tag标记的标记体中使用返回的对象
AT_END:在Tag标记结束后,才能返回对象
看例子:
example3_4.jsp将String对象交给Tag文件handleDtata.Tag,解析出来的数据,然后返回给JSP页面
example3_4.jsp
<%@ page contentType="text/html" %>
<%@ page pageEncoding = "utf-8" %>
<%@ taglib tagdir="/WEB-INF/tags/example4" prefix="getPrice" %>
<HTML><body bgcolor = #FFCCFF>
<% String str = "麻辣豆腐:20.6元,红烧肉:68.9元,烤鸭:199元";
%>
<getPrice:handleData mess="<%= str %>"/> <%-- 使用Tag标记 --%>
<p style="font-family:宋体;font-size:36">
菜单:<br>"<%= str %>"<br>价格总和:
<%= price %> <%-- 使用Tag标记返回的Double对象price --%>
</p>
<% str = "毛巾:2.6元,香皂:6.9元,牙刷:12.3元";
%>
<getPrice:handleData mess="<%= str %>"/>
<p style="font-family:黑体;font-size:36;color:blue">
购物小票:<br>"<%= str %>"<br>价格总和:
<%= price %>
</p>
</body></HTML>
handleData.tag
<%@ attribute name="mess" required="true" type="java.lang.String" %>
<%@ tag import="java.util.regex.Pattern" %>
<%@ tag import="java.util.regex.Matcher" %>
<%@ variable name-given="price" variable-class="java.lang.Double"
scope="AT_BEGIN" %>
<%!
public Double getPriceSum(String input){ // 定义方法
Pattern pattern; //模式对象
Matcher matcher; //匹配对象
String regex="-?[0-9][0-9]*[.]?[0-9]*" ;//匹配数字,整数或浮点数的正则表达式
pattern = Pattern.compile(regex); //初试化模式对象
matcher = pattern.matcher(input); //初始化匹配对象,用于检索input
double sum = 0;
while(matcher.find()) {
String str = matcher.group();
sum += Double.parseDouble(str);
}
return new Double(sum);
}
%>
<% //将返回的Double对象放在jspContext中:
jspContext.setAttribute("price",getPriceSum(mess));
%>
3.3.5 taglib指令
引入标记库,格式如下:
<%@ taglib tagdir=“自定义标记库位置” prefix=“前缀”>
总结
明天五一放假,晚安!