JSTL之迭代标签库
JSTL之迭代标签库
JSTL的全称是 Java Server Pages Standard Tag Library,翻译过来就是JSP标准标签库,它包含了在开发JSP页面时经常用到的一组标准标签。这些标签提供了一种不用嵌入Java代码就可以开发复杂的JSP页面的方法。
在JSTL中一共有5大类标签库,其中有一个重要的核心标签库,而核心标签库根据功能不同又分为通用标签库、条件标签库、迭代标签库,今天我们要说的就是其中的迭代标签库。
在JSP的开发中,我们经常需要对集合对象进行迭代操作。例如,列表显示查询结果等,以往通常使用java代码实现集合对象的遍历,如List,Iterator等。现在我们所说的JSTL的迭代标签可以在很大程度上简化迭代操作。
<c:forEach>标签有两种语法格式,一种用于遍历集合对象的成员,另一种用于使语句循环执行指定的次数,下面我们来一一列举。
1.遍历集合对象的成员
<c:forEach var="varName" items="collectionName" varStatus="varStatuwsName"
begin="beginIndex" end="endIndex" step="step">显示内容</c:forEach>
上面就是一个forEach标签的基本语法格式,其中var属性是代表当前遍历的成员,items是指被迭代的集合对象,varStatus属性用于存放var引用的成员的相关信息,如索引等,begin表示开始的位置,默认为0,end表示结束为止,step表示循环的步长,默认为1。好了,现在我们已经知道了他的基本语法和各属性的作用,那么把他带入到程序中是怎样的呢?下面就用一个简单的Demo来个大家一个直观的呈现:
<%
List<String> list = new ArrayList<String>();
list.add("小明");
list.add("小红");
list.add("小刚");
request.setAttribute("list",list);
%>
<c:forEach var="varName" items="${list}" varStatus="varStatusName">
${varName}
</c:forEach>
这样就实现了一个简单的迭代效果,一般JSTL标签要和EL表达式联用,这样就可以简便的获取和输出数据。大家也看到了,这样直接遍历循环对象很简单,那么我们继续看他的下一种语法格式,也就是指定语句的执行次数。
2.指定语句的执行次数:
<c:forEach var="varName" varStatus="varStatuwsName"
begin="beginIndex" end="endIndex" step="step">显示内容</c:forEach>
是不是看起来很熟悉呢,他的语法和上面没有太大不同,区别就是格式2不是对一个集合对象遍历,而是根据制定的begin属性,end属性以及step属性执行主体内容固定的次数。这种方法在实际开发中非常广泛,在很多开发中都要显示列表,报表,下面我们就用一个人员列表隔行变色的核心代码来演示他的效果:
<table style="border:1px solid blue; width: 400px;">
<tr style="font-weight: bold; ">
<td>姓名</td><td>职位</td><td>年龄</td>
</tr>
<!--在servlet页面已经加进去一个集合-->
<c:forEach var="varName" items="${list}" varStatus="status">
<tr <c:if test="${status.index%2==0}">style="background-color: pink"</c:if></tr>
<td>${varName.name}</td><td>${varName.job}</td><td>${varName.age}</td>
</tr>
</c:forEach>
</table>
这样就有了一个好看的隔行变色效果:

是不是很好用呢?如果要用jquery或是HTML代码实现这种和数据库连接的样式会非常麻烦,使用JSTL标签让代码变得简便,并且其中的条件标签可以让代码多出更多的变化。
JSTL之迭代标签库的更多相关文章
- (5)JSTL的xml标签库
Jstl的XML标签库 JSTL提供了操作xml文件的标签库,使用xml标签库可以省去使用Dom和SAX标签库的繁琐,能轻松的读取xml文件的内容. <%@ taglib uri="h ...
- (4)JSTL的SQL标签库
jstl的SQL标签库 SQL tag Library中的标签用来提供在 JSP 页面中可以与数据库进行交互的功能Database access标签库有以下6组标签来进行工作: <sql:set ...
- JSTL I18N 格式标签库
<%@ page language="java" pageEncoding="gbk"%> <%@ taglib prefix="c ...
- Java_jsp.jstl.Function函数标签库.记录
JSTL Functions标签库 本书第12章的12.3节(定义和使用EL函数)介绍了EL函数的创建和使用方法.在JSTL Functions标签库中提供了一组常用的EL函数,主要用于处理字符串,在 ...
- JSTL (标准标签库)
JSTL(标准标签库) 作用: Web程序员能够利用JSTL和EL来开发Web程序,取代传统直接在页面上嵌入Java程序(Scripting)的做法,以提高程序的阅读性.维护性和方便性. 使用方法:J ...
- JSTL 数字日期标签库
<frm:formatNumber/>标签 该标签依据特定的区域将数字改变为不同的格式来显示. 被格式化的数据<frm:formatNumber> <fmt:format ...
- JSTL标签库之核心标签
一.JSTL标签库介绍 JSTL标签库的使用是为弥补html标签的不足,规范自定义标签的使用而诞生的.使用JSLT标签的目的就是不希望在jsp页面中出现java逻辑代码 二.JSTL标签库的分类 核心 ...
- jstl标签库基础教程及其使用代码
概述 在 JSP 页面中,使用标签库代替传统的 Java 片段语言来实现页面的显示逻辑已经不是新技术了,然而,由自定义标签很容易造成重复定义和非标准的实现.鉴于此,出现了 JSTL ( JSP Sta ...
- JSTL标签库大全
JSTL简介: 标准标签库JSTL的全名为:Java Server Pages Standard Tag Library. JSTL主要提供了5大类标签库: 1. 核心标签库: 为日常任务 ...
随机推荐
- CSDN首页> 移动开发 直接拿来用!最火的Android开源项目(完结篇)
此前,CSDN移动频道推出的GitHub平台上“最受欢迎的开源项目”系列文章引发了许多读者的热议,在“直接拿来用!最火的Android开源项目”系列文章(一).(二)中,我们也相继盘点了40个GitH ...
- 在与SQL Server建立连接时出现与网络相关的或特定于实例的错误
向往前一样.学习牛腩新闻公布系统的视频,写程序,打开数据库.出现一个框框,具体内容例如以下: 数据库连接不上.全部的工作都要歇班,捣鼓了会儿,简单总结一下解决该问题的方法. 首先:第一步,程序--SQ ...
- 转--23种设计模式的搞笑解释(后续放逐一C++解释版本)
创建型模式 1.FACTORY —追MM少不了请吃饭了,麦当劳的鸡翅和肯德基的鸡翅都是MM爱吃的东西,虽然口味有所不同,但不管你带MM去麦当劳或肯德基,只管向服务员说“来四个鸡翅”就行了.麦当劳和肯德 ...
- php动态调用方法_sux
<form action=""> <input type="hidden" name="mod" id="mo ...
- Dubbo架构设计详解--转载
原文地址:http://shiyanjun.cn/archives/325.html Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解 ...
- 微软Hololens学院教程- Holograms 100: Getting Started with Unity【微软教程已经更新,本文是老版本】
这是老版本的教程,为了不耽误大家的时间,请直接看原文,本文仅供参考哦!原文链接:https://developer.microsoft.com/EN-US/WINDOWS/HOLOGRAPHIC/ho ...
- iOS 本地自动打包工具
1.为什么要自动打包工具? 每修改一个问题,测试都让你打包一个上传fir , 你要clean -> 编译打包 -> 上传fir -> 通知测试.而且打包速度好慢,太浪费时间了.如果有 ...
- iOS开发技巧系列---使用链式编程和Block来实现UIAlertView
UIAlertView是iOS开发过程中最常用的控件之一,是提醒用户做出选择最主要的工具.在iOS8及后来的系统中,苹果更推荐使用UIAlertController来代替UIAlertView.所以本 ...
- iOS-MVVM设计模式
谈到MVVM不得不先说一下MVC,MVC(Model-View-Controller). Model模型:用来呈现数据. View视图:用来呈现用户界面. Controller控制器:用来调节模型与视 ...
- 大设计时代:针对超大网页布局的一些思考和建议 [Aseoe]
对于有些设计项目来说,老套的设计模式并不奏效,你需要设计的大点,要比以往设计的元素还要大,因此就非常适合采用超大网页布局.无论是采用大块大块的背景照片还是背景视频,超大网页布局的效果非常显著:极具视觉 ...