Tag文件与Tag标记




前言

本章主要内容为Tag文件的结构,Tag标记以及Tag文件中的常用指令。其中难点为Tag文件中的attribute指令和variable指令。


一、Tag文件

1.1 Tag文件的结构

Tag文件是拓展名为.tag的文件,其内容中可以有普通的HTML标记符、某些特殊的指令标记、成员变量声明和方法的定义、java程序片和java表达示。

1.2 Tag文件的保存

1.2.1 Tag文件的保存目录

Tag文件可以实现代码的复用,即一个Tag文件可以被多个jsp页面使用。为了能让一个Web应用中的jsp页面可以使用一个Tag文件,必需把这个Tag文件存放到Tomcat服务器的指定目录中。

如下例:

Web服务目录\WEB-INF\tags

其中WEB-INF和tags都是固定的名称。tags文件下的子目录可以由用户自己设置。

1.2.2 Tag文件的编码

保存Tag文件时按照Tag文指定的编码保存。

如:

<%@ tag pageEncoding = "utf-8" %>

使用tag指令指定编码为utf-8,所以保存文件时用utf-8编码保存。

二、Tag标记

2.1 Tag标记与Tag文件

一个Tag文件只能由对应的Wbe服务目录中的jsp页面调用,jsp页面必须通过Tag标记来调用一个Tag文件。一个Tag文件对应一个Tag标记,把全体Tag标记称之为一个标记库。

Tag标记格式为:

<Tag文件的名字 />
或
<Tag文件的名字>其他内容</Tag文件的名字>

2.2 Tag标记的使用

使用Tag标记调用一个Tag文件前,必需使用taglib指令标记引入该web服务目录下的标记库

tablib指令格式如下:

<%@ taglib tagdir = "标记库的位置" prefix = "前缀" %>

使用Tag指令调用Tag文件:

<computer:oddNumberSum />

computer 为prefix给出的前缀,用户可自定义,注意冒号:前后没有空格。

jsp文件

<%@ 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文件

<%@ tag pageEncoding="utf-8" %>
<p style="font-family:宋体;font-size:36">
1~100内的奇数之和:
  <%  int sum=0,i=1;
         for(i=1;i<=100;i++){
            if(i%2==1)
               sum=sum+i;
        }
        out.println(sum);
  %> 
</p>

运行结果

三、Tag文件中的常用指令

3.1 tag指令

Tag文件中的tag指令类似与jsp文件中的page指令。用来指定某些属性的值:

<%@ tag属性 = "属性值" %>

tag指令可以同时指定多个属性。

3.2 include指令

与jsp文件中的include类似,用法也类似。

3.3 attribute指令

attribute指令在Tag文件中为传递数据作用。在Tag文件中通过使用attribute指令让使用它的jsp页面

向该Tag文件传递需要的数据:

<%@ attritube name="对象名字" required="true"|"flase" type="对象的类型"%>

attribube指令中的name属性是必需的,该值是一个对象的名字。

jsp页面使用Tag标记向所调用的Tag文件中name指定的对象传递一个引用,方式如下:

<前缀:Tag文件的名字 对象的名字="对象的引用" />

例:

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>

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));
%>

运行结果: 

 

3.4 variable指令

variable指令与attribute指令相反,为返回指令即Tag文件返回数据给jsp页面

其格式如下:

<%@ variable name-given="对象名" variable-class="对象类型" scope = "有效范围"%>

其中scope取值可以为AT_BEGIN 开始使用Tag标记即获得了返回的对象、NESTEN jsp页面只能在Tag标记体中获得返回的对象、AT_END 在Tag标记结束后获得返回的对象.

为了返回对象给jsp页面就必须将返回的对象的名字和对象的引用存储到Tomcat服务器提供的内置对象jspContext中。

例:

<%@ variable name-given="time" variable-class="java.time.LocalDate" scope = "AT_END"%>
setAtteribute("对象名",对象的引用);
上述例子存储为
jspContext.setAtteribute("time",LocalDate.now());

返回对象示例:

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>

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.5 taglibe指令

为引入标记库指令:

<%@ taglib tagdir = "标记库的位置" prefix = "前缀" %>


总结

上述就是Tag文件及Tag标记的所有内容,其与jsp页面类似,为jsp页面实现更多功能提供帮助,是非常重要的知识点,应熟练掌握

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值