标签与el表达式联合的使用

首先给大家推荐一下我老师大神的人工智能教学网站。教学不仅零基础,通俗易懂,而且非常风趣幽默,还时不时有内涵黄段子!点这里可以跳转到网站

<span style="font-size:24px;color:#ff0000;"><strong><c:foreach>常用的用法</strong></span><span style="color: rgb(51, 51, 51); font-size: 14px;">转的,可以用来作为自己的学习笔记<c:foreach>类似于for和foreach循环   以下是我目前见过的用法: 1、循环遍历,输出所有的元素。 <c:foreach items="${list}" var="li"> ${li} </c:foreach> 注意:items 用于接收集合对象,var 定义对象接收从集合里遍历出的每一个元素。同时其会自动转型。 2、循环遍历,输出一个范围类的元素。 <c:foreach items ="${lis}" var = "li " begin="2" end ="12"> ${li} </c:foreach> 注意:begin 定义遍历的开始位置,end定义遍历的结束位置。begin 和end的引号必须写。 3、循环遍历,输出除某个元素以外的元素或输出指定元素。 <c:foreach items="${list}" var ="li" varStatus="status"> <c:if text="${status.count==1}> ${"第一个元素不要"} </c:if> ${li} </ c:foreach> 注意:varStatus 表示当前集合的状态(其实是不是,我也不太清楚,只知道这样用,会的人指点下),count为循环一个计算器。 4、循环遍历,输出第一个或最后一个元素。 <c:foreach items="${list}" var ="li" varStatus="status"> <c:if test="${status.first}">我是第一个元素</c:if> <c:if test="${status.last}">我是最后一个元素</c:if> </c:foreach> 注意:first表示如果是一个元素,则返回ture,反之则返回false            last 表示如果是最后一个元素,则返回ture,反之则返回false。5、循环遍历,按指定步长输出。<c:foreach items="list" var ="li" step="2">${li}</c:foreach>注意:step为循环的步长。每次隔两个单位输出一个。如:1、3、5、==</span>
<span style="font-size:24px;color:#ff0000;"><strong><c:foreach>详细的用法</strong></span>
在JSP的开发中,迭代是经常要使用到的操作。例如,逐行的显示查询的结果等。在早期的JSP中,通常使用Scriptlets来实现Iterator或者Enumeration对象的迭代输出。现在,通过JSTL的迭代标签可以在很大的程度上简化迭代操作。         JSTL所支持的迭代标签有两个,分别是<c:forEach>和<c:forTokens>。在这里介绍的是<c:forEach>标签。         简单点说,<c:forEach>标签的作用就是迭代输出标签内部的内容。它既可以进行固定次数的迭代输出,也可以依据集合中对象的个数来决定迭代的次数。         <c:forEach>标签,需要与el表达式联合使用         <c:forEach>标签的语法定义如下所示。                   <c:forEach var="每个变量名字"   items="要迭代的list"   varStatus="每个对象的状态"                            begin="循环从哪儿开始"    end="循环到哪儿结束"    step="循环的步长">                               循环要输出的东西                   </c:forEach>          <c:forEach>标签具有以下一些属性: l          var:迭代参数的名称。在迭代体中可以使用的变量的名称,用来表示每一个迭代变量。类型为String。  l          items:要进行迭代的集合。对于它所支持的类型将在下面进行讲解。  l          varStatus:迭代变量的名称,用来表示迭代的状态,可以访问到迭代自身的信息。  l          begin:如果指定了items,那么迭代就从items[begin]开始进行迭代;如果没有指定items,那么就从begin开始迭代。它的类型为整数。 l          end:如果指定了items,那么就在items[end]结束迭代;如果没有指定items,那么就在end结束迭代。它的类型也为整数。 l          step:迭代的步长。           <c:forEach>标签的items属性支持Java平台所提供的所有标准集合类型。此外,您可以使用该操作来迭代数组(包括基本类型数组)中的元素。它所支持的集合类型以及迭代的元素如下所示: l          java.util.Collection:调用iterator()来获得的元素。  l          java.util.Map:通过java.util.Map.Entry所获得的实例。  l          java.util.Iterator:迭代器元素。  l          java.util.Enumeration:枚举元素。  l          Object实例数组:数组元素。  l          基本类型值数组:经过包装的数组元素。  l          用逗号定界的String:分割后的子字符串。  l          javax.servlet.jsp.jstl.sql.Result:SQL查询所获得的行。           不论是对整数还是对集合进行迭代,<c:forEach>的varStatus属性所起的作用相同。和var属性一样,varStatus用于创建限定了作用域的变量(改变量只在当前标签体内起作用)。不过,由varStatus属性命名的变量并不存储当前索引值或当前元素,而是赋予javax.servlet.jsp.jstl.core.LoopTagStatus类的实例。该类包含了一系列的特性,它们描述了迭代的当前状态,如下这些属性的含义如下所示: l          current:当前这次迭代的(集合中的)项。  l          index:当前这次迭代从0开始的迭代索引。  l          count:当前这次迭代从1开始的迭代计数。  l          first:用来表明当前这轮迭代是否为第一次迭代,该属性为boolean类型。  l          last:用来表明当前这轮迭代是否为最后一次迭代,该属性为boolean类型。  l          begin:begin属性的值。  l          end:end属性的值  l          step:step属性的值  下面就来看两个基本的例子,第一个例子是依次输出集合内的元素。 <c:forEach var="item" items="${contents}" varStatus="status">         $status.count:${item} </c:forEach> 下面的例子是一个固定次数的迭代,用来输出1到9的平方。 <c:forEach var="x" begin="1"end="9" step="1">          ${x*x} </c:forEach>下面写一下,我做的项目中用到的例子:分页:     <table>       <tr><th>名字</th><th>说明</th><th>图片预览</th></tr>        <c:forEach items="${data}" var="item">            <tr><td>${item.advertName}</td><td>${item.notes}</td><td><img src="${item.defPath}"/></td></tr>        </c:forEach>     </table>    <ul>        <li><a href='?nowPage=${nowPage-1}'>←上一页</a></li>                   <c:forEach varStatus="i" begin="1" end="${sumPage}">                        <c:choose>                           <c:when test="${nowPage==i.count}">                              <li class='disabled'>${i.count}</li>                           </c:when>                           <c:otherwise>                               <li  class='active'><a href='?nowPage=${i.count}'>${i.count}</a></li>                           </c:otherwise>                        </c:choose>                   </c:forEach>            <li><a href='?nowPage=${nowPage+1}'>下一页→</a></li>      </ul>首页展示图片的例子:迭代后台传过来的list, src的路径要写绝对路径,写成相对路径会报错,有时绝对路径用<c:ulr>来写           <c:forEach items="${lists}" var="item">             <img id="img${i}" height="250" width="500"  class="img" src='UploadImages/${item.advertPath}'/>            </c:forEach>获得下标,其中size是后台传过来的list的长度,此处不能写成end="${list.size}"              <c:forEach begin="1" end="${size}"  step="1" varStatus="i">                    <li> <a href="http://www.baidu.com/" class="showimg">${i.index}</a></li>                 </c:forEach>

点这里可以跳转到人工智能网站

发表评论