• Jstl标签的使用


    一. 配置 JSTL

    包括两个 JAR 文件, jstl.jar 和 standard.jar 。是什么没有必要管,重在应用( 1+1 ? =2 ,我们没有必要深究,只需要知道这么用就行。)。

    原文引入:

    <%@ 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 rui=”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>

    <sql:query var="queryAllChannelCount">

    SELECT COUNT(*) as total FROM tb_channel WHERE game_id=? AND begin_round<func_cur_round(?) AND player_id=? AND channel_flag=0

    <sql:param value="${gameID}"/>

    <sql:param value="${gameID}"/>

    <sql:param value="${playerID}"/>

    </sql:query>

    <c:forEach items="${queryAllChannelCount.rowsByIndex}" var="channelCN">

           <c:set value="${channelCN[0]}" var="channelTotal"/>

    </c:forEach>

    调用存储过程更新数据库:

    <c:if test="${param.changsubmit!=null}" >

    <c:forEach items="${paramValues.pro_id}" var="getpro_id" varStatus="getparamsta">

    <sql:update>

    call proc_set_role_product(?,?,?,?,?,?,?,?);

    <sql:param value="${gameID}"/>

    <sql:param value="${playerID}"/>

    <sql:param value="${getpro_id}"/>

    <sql:param value="${getpro_id}"/>

    <sql:param value="${paramValues.pro_sort[getparamsta.index]}"/>

    <sql:param value="${paramValues.price[getparamsta.index]}"/>

    <sql:param value="${paramValues.output[getparamsta.index]}"/>

    <sql:param value="0"/>

    </sql:update>

    </c:forEach>

    </c:if>

    四. 格式化标签

    <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

    补充知识点:

    1. 替换 request.getParameter("test"):

    <c:if test="${param.test!=null}" >

    <c:out value="${param.test}" />

    </c:if>

    2. <c:redirect url="a.jsp">

    3.<c:redirect url="/max.jsp" context="/ch16">

    <c:param name="name1" value="665"/>

    <c:param name="name3" value=" 斯蒂芬 "/>

    </c:redirect>

    4.<c:forTokens items="zhangsan:lisi:as" delims=":" var="name">

    ${name}

    </c:forTokens>

    From:http://blog.sina.com.cn/s/blog_4550f3ca010143lb.html

    另:

    el表达式判断一个对象是否为空,用empty关键字即可,当然,在前面加上!表示不为空,示例如下:

    <c:if test="${empty mylist}">mylist为空</c:if>

    <c:if test="${!empty mylist}">mylist不为空</c:if> 

     
     
     
  • 相关阅读:
    告诉自己的十大忠告
    深度学习框架
    深度学习-Caffe编译测试的小总结
    深度学习-Windows平台下的Caffe编译教程
    C#中使用多款LevelDB.Net封装测试性能
    LevelDB初体验测试
    机器学习-分类器-Adaboost原理
    机器学习-分类器-级联分类器训练(Train CascadeClassifier )
    C# Directory.GetFiles()获取多个类型格式的文件
    部分Android或IOS手机拍照后照片被旋转的问题
  • 原文地址:https://www.cnblogs.com/geekdc/p/5232034.html
Copyright © 2020-2023  润新知