java c foreach_<c:forEach>

编辑

锁定

讨论

上传视频

本词条缺少概述图,补充相关内容使词条更完整,还能快速升级,赶紧来编辑吧!

为循环控制,它可以将集合(Collection)中的成员循序浏览一遍。运作方式为当条件符合时,就会持续重复执行的本体内容。

中文名

·var

迭代参数的名称·items

要进行迭代的集合

·varStatus

迭代变量的名称

简介

编辑

语法

语法1:迭代一集合对象之所有成员

[begin="begin"] [end="end"] [step="step"]>

本体内容

编辑

语法2:迭代指定的次数

属性

编辑

·var:迭代参数的名称。在迭代体中可以使用的变量的名称,用来表示每一个迭代变量。类型为String。

·items:要进行迭代的集合。

·varStatus:迭代变量的名称,用来表示迭代的状态,可以访问到迭代自身的信息。

·begin:如果指定了items,那么迭代就从items[begin]开始进行迭代;如果没有指定items,那么就从begin开 始迭代。它的类型为整数。

·end:如果指定了items,那么就在items[end]结束迭代;如果没有指定items,那么就在end结束迭代。它的类 型也为整数。

·step:迭代的步长。

·current:当前这次迭代的(集合中的)项。

·index:当前这次迭代从0开始的迭代索引。

·count:当前这次迭代从1开始的迭代计数。

·first:用来表明当前这轮迭代是否为第一次迭代,该属性为boolean类型。

·last:用来表明当前这轮迭代是否为最后一次迭代,该属性为boolean类型。

·begin:begin属性的值。

·end:end属性的值

·step:step属性的值

限制

·假若有begin属性时,begin必须大于等于 0

·假若有end属性时,必须大于等于begin

·假若有step属性时,step必须大于等于0

Null 和 错误处理

·假若items为null时,则表示为一空的集合对象

·假若begin大于或等于items时,则迭代不运算

说明

如果要循序浏览一个集合对象,并将它的内容显示出来,就必须有items属性。

items支持的类型包括:

·java.util.Collection:调用iterator()来获得的元素。

·java.util.Map:通过java.util.Map.Entry所获得的实例。

·java.util.Iterator:迭代器元素。

·java.util.Enumeration:枚举元素。

·Object实例数组:数组元素。

·基本类型值数组:经过包装的数组元素。

·用逗号定界的String:分割后的子字符串。

·javax.servlet.jsp.jstl.sql.Result:SQL查询所获得的行。

范例

编辑

下面的范例 Core_forEach.jsp是将数组中的成员一个个显示出来的: 􀂄

Core_forEach.jsp

CH7 - Core_forEach.jsp

String atts[] = new String [5];

atts[0]="hello";

atts[1]="this";

atts[2]="is";

atts[3]="a";

atts[4]="pen";

request.setAttribute("atts", atts);

%>

${item}

在上述范例中,笔者先产生一个字符串数组,然后将此数组atts储存至Request的属性范围中,再用将它循序浏览一遍。这里items表示被浏览的集合对象,var用来存放指定的集合对象中成员,最后使用将item的内容显示出来,执行结果如图-8所示。

注意

编辑

varName的范围只存在的本体中,如果超出了本体,则不能再取得varName的值。上个例子中,若${item} 是在之后执行时,如:

${item}

${item}则不会显示item的内容。

除了支持数组之外,还有标准J2SE的集合类型,例如:ArrayList、List、LinkedList、Vector、Stack和Set 等等;另外还包括java.util.Map类的对象,例如:HashMap、Hashtable、Properties、Provider和Attributes。

还有begin、end和step这三种属性:begin主要用来设定在集合对象中开始的位置(注意:第一个位置为0);end用来设定结束的位置;而step则是用来设定成员和下一个将被指到成员之间的间隔。我们将之前的范例改成如下:

Core_forEach1.jsp 􀂄

CH7 - Core_forEach1.jsp

atts[0]="hello";

atts[1]="this";

atts[2]="is";

atts[3]="a";

atts[4]="pen";

request.setAttribute("atts", atts);

%>

${item}

中指定的集合对象atts将会从第2个成员开始到第5个成员,并且每执行一次循环都会间隔一个成员浏览。因此结果是只显示atts[1]和atts[3]的内容,如图7-9所示。

特别注意:直接是使用不了的,需要导入两个包

jstl-1.2-sources.jar

jstl-1.2.jar

(就是jstl和standard这两个包)

不导入运行会报错~~~提醒大家~~~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JSTL(JSP Standard Tag Library ,JSP标准标签库)是一个不断完善的开放源代码的JSP标签库,是由apache的jakarta小组来维护的。JSTL只能运行在支持JSP1.2和Servlet2.3规范的容器上,如tomcat 4.x。在JSP 2.0中也是作为标准支持的。   JSTL 1.0 发布于 2002 年 6 月,由四个定制标记库(core、format、xml 和 sql)和一对通用标记库验证器(ScriptFreeTLV 和 PermittedTaglibsTLV)组成。core 标记库提供了定制操作,通过限制了作用域的变量管理数据,以及执行页面内容的迭代和条件操作。它还提供了用来生成和操作 URL 的标记。顾名思义,format 标记库定义了用来格式化数据(尤其是数字和日期)的操作。它还支持使用本地化资源束进行 JSP 页面的国际化。xml 库包含一些标记,这些标记用来操作通过 XML 表示的数据,而 sql 库定义了用来查询关系数据库的操作。   两个 JSTL 标记库验证器允许开发人员在其 JSP 应用程序中强制使用编码标准。可以配置 ScriptFreeTLV 验证器以在 JSP 页面中禁用各种类型的 JSP 脚本元素 — scriptlet、表达式和声明。类似地,PermittedTaglibsTLV 验证器可以用来限制可能由应用程序的 JSP 页面访问的定制标记库集(包括 JSTL 标记库)。   尽管 JSTL 最终将会成为 J2EE 平台的必需组件,但目前只有少数应用程序服务器包括它。JSTL 1.0 的参考实现可作为 Apache 软件基金会(Apache Software Foundation)的 Jakarta Taglibs 项目(请参阅参考资料)的一部分而获得。可以将该参考实现中的定制标记库合并到任何支持 JSP 1.2 和 Servlet 2.3 规范的服务器,以添加对 JSTL 的支持。   如果要使用JSTL,则必须将jstl.jar和 standard.jar文件放到classpath中,如果你还需要使用XML processing及Database access (SQL)标签,还要将相关JAR文件放到classpath中,这些JAR文件全部存在于下载回来的zip文件中。这个zip文件可以从http://jakarta.apache.org/builds/jakarta-taglibs/releases/standard/jakarta-taglibs-standard-1.0.zip下载。 .

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值