JSTL的用法

JSP 标准标记库(Standard Tag Library,JSTL)是一组以标准化格式实现许多通用的Web站点功能的定制标记。 JSTL的目标是为了简化JSP 页面的设计。

一.配置JSTL

包括两个JAR文件,jstl.jar 和standard.jar。是什么没有必要管

原文引入:


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>

<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>

                                                           

二.Core标签库



Core标签库主要包括了一般用途的标签、条件标签、迭代标签和URL相关的标签。在JSP页面使用Core标签,要使用taglig指令,指定引用的标签库,如下:

<%@ taglib uri=”http://java.sun.com/jsp/jstl/core” prefix=”c” %>


一般用途的标签有<c:out>、<c:set>、<c:remove>、<c:cath>

1.<c:out>

用于计算一个表达式并将结果输出。类似于JSP 中<%=%>表达式,或者是EL中$ ${el-expression}。

2.<c:set>

用于设置范围变量的值或者javabean对象的属性。

看个实际例子:

<c:set var=”username” value=”lisi” scope=”session”/>
这样就相当于设置了session。

3.<c:remove>

相对<c:set>其作用是移除范围变量。比如

<c:remove var=”nusername” scope=”session”/>

4.<c:catch>

用于捕获在其中嵌套的操作所抛出的异常对象,并将异常信息保存到变量中。

我们将有可能抛出异常的代码放置到开始标签:<c:catch>和结束标签:</c:catch>之间。如果其中代码出现异常,异常对象将被捕获,保存在var声明的变量中,该变量总是有page范围。如果没有发生异常,而var所标识的范围变量将被移除。

如果没有指定var属性,异常只是简单的被捕获,异常信息并不会被保存。

Eg:


<c:catch var=”exception”>
<%
       int i = 5;
       int j = 0;
       int k=i/j;
%>
</c:catch>
<c:out value=”${exception}” /><br>
<c:out value=”${exception.massage}”/>


后一句相当于:exception.getMessage()



条件标签包括<c:if><c:choose><c:when><c:otherwise>

1.<c:if>
用于实现java中的if语句功能。

<c:if test=”${user.visitCount==1}”>

       This is your first visit .

</c:if>

若为true,会打印中间部分。也可以声明var,方便下一步判断。



<c:if test=”${param.name==’admin’}” value=”result”/>
<c:out value=”${result}” />

2.<c:choose>
<c:choose>和<c:when>、<c:otherwise>一起实现互斥条件执行,类似于java中的if else.
<c:choose>一般作为<c:when>、<c:otherwise>的父标签。

eg:

<c:choose>
       <c:when test="${row.v_money<10000}">
              初学下海
       </c:when>
       <c:when test="${row.v_money>=10000&&row.v_money<20000}">

            身手小试
        </c:when>
       <c:otherwise>
              商业能手
       </c:otherwise>
</c:choose>



迭代标签 迭代标签有<c:forEach>和</c:forEach>
//遍历记录集

<c:forEach items="${finalResult.rows}" var="row">       
<tr class="<%=tdClass[(rank+1)%2]%>">
<td align="center"><span><%=rank%> </span></td>
<td align="center"><span ><c:out value="${row.player_name}"/></span> </td>
<td align="center"><span >¥<c:out value="${row.money}"/></span></td>
</tr>
<%rank++;%>     
</c:forEach>



也可以设定固定次数。



<c:forEach var =”i” begin=”100 “ end= “110”>

       ${i}

</c:forEach>



如果再加个step=“2”那么每次增长为2。



三.sql标签



//设置数据源:

<sql:setDataSource dataSource="proxool.breadTycoon" />
//将数据库某查询的结果声明为一个变量

<sql:query var="finalResult" >
    select player_name,money from tb_player order by money DESC LIMIT 10   
</sql:query>


       然后可以:

<c:forEach items="${ finalResult.rows}" var="row" varStatus="s">

        advCosts[${s.index}]=${row.adv_cost};

   </c:forEach>


      数据更新标签:

     <sql:update>  
                call proc_set_role_salespro(?,?,?,?,?);
                <sql:param value="30"/>
                <sql:param value="39"/>
                <sql:param value="<%=spID%>"/>
                <sql:param value="<%=productID%>"/>
                <sql:param value="1"/>               
     </sql:update>



四.格式化标签

<fmt: formatNumber value =”12.3” pattern=”.000”/>
将输出12.300.应用样式”.000”,将使格式化后的小数部分有3位。不足3位将以0补齐

   <fmt:formatDate value=”<%=new java.util.Date() %>” type=”date” />

格式化的结果是:2007-5-27.

<fmt:formatDate value=”<%=new java.util.Date() %>” type=”time” />
格式化的结果是:9:25:11

<fmt:formatDate value=”<%=new java.util.Date() %>” type=”both” />


格式化的结果是: 2007-5-27 9:25:11


fn函数
JSTL1.1标签库还包含了许多其它经常使用的函数:

fn:contains(string, substring)
如果参数string中包含参数substring,返回true

fn:containsIgnoreCase(string, substring)
如果参数string中包含参数substring(忽略大小写),返回true

fn:endsWith(string, suffix)
如果参数 string 以参数suffix结尾,返回true

fn:escapeXml(string)
将有特殊意义的XML (和HTML)转换为对应的XML character entity code,并返回

fn:indexOf(string, substring)
返回参数substring在参数string中第一次出现的位置

fn:join(array, separator)
将一个给定的数组array用给定的间隔符separator串在一起,组成一个新的字符串并返回。

fn:length(item)
返回参数item中包含元素的数量。参数Item类型是数组、collection或者String。如果是String类型,返回值是String中的字符数。

fn:replace(string, before, after)
返回一个String对象。用参数after字符串替换参数string中所有出现参数before字符串的地方,并返回替换后的结果

fn:split(string, separator)
返回一个数组,以参数separator 为分割符分割参数string,分割后的每一部分就是数组的一个元素

fn:startsWith(string, prefix)
如果参数string以参数prefix开头,返回true

fn:substring(string, begin, end)
返回参数string部分字符串, 从参数begin开始到参数end位置,包括end位置的字符

fn:substringAfter(string, substring)
返回参数substring在参数string中后面的那一部分字符串

fn:substringBefore(string, substring)
返回参数substring在参数string中前面的那一部分字符串

fn:toLowerCase(string)
将参数string所有的字符变为小写,并将其返回

fn:toUpperCase(string)
将参数string所有的字符变为大写,并将其返回

fn:trim(string)
去除参数string 首尾的空格,并将其返回

主要是替换
<sql:setDataSource var="dataSrc"
    url="jdbc:jtds:sqlserver://localhost/LOG_DB" driver="net.sourceforge.jtds.jdbc.Driver"
    user="sa" password="admin"/>
    <%-- Set number of rows to process --%>
    <c:set var="noOfRows" value="100" />
    <c:set var="msg" value="select top 100 * from L_ips_tb where id> (select max (id) from
(select top ard id from L_ips_tb order by id) as T
)     order by id"/>
<c:set var="test" value="${fn:replace(msg,'ard',100)}" />

<c:out value="${test}" />
    <sql:query var="empList"
      sql="${test}"       dataSource="${dataSrc}"
    />
   <c:out value="${fn:length(empList.rows)}"/>
使用反射
<c:setvar="arrayvalue"value="ID,SrcIP"/>
<c:setvar="delim"value=","/>
<c:setvar="array"value="${fn:split(arrayvalue,delim)}"/>
<c:setvar="count"value="${fn:length(array)}"/>


array是一个String数组,loghistory是一个Map

<c:forEachvar="loghistory"items="${loghistory}"varStatus="statusindex">

<c:forEachbegin="0"end="${count-1}""varStatus="index">
<c:outvalue="${loghistory[array[index.index]]}"/>
</c:forEach>
<c:choose>

使用二维数组
<c:forEach items="${applicationScope[param.answersMapName]}"
          var="a">
          ${a.key}) ${a.value}:
          ${applicationScope[param.votesMapName][a.key]}<br>
        </c:forEach〉

你可能感兴趣的:(sql,C++,c,jsp,sun)