jstl和el表达式都是用来替代jsp页面中的复杂代码的,在学习他们时,通常是先学el表达式。
EL即expression language (表达式语言),它的基本语法格式是用美元符号($)定界,内容包括在花括号({})中,即 ${对象名.属性名},el的另一种格式是 ${对象名['属性名']},一般采用的是前一种格式。
EL 除了提供方便存取变量的语法之外,它另外一个方便的功能就是:自动转变类型,即它能根据{}中的内容转变成相应的数据类型,如:{}中是boolean型,如果传过来的参数不是boolean,经过el表达式自动转成boolean。
EL隐藏对象
pageContext
pageScope
requestScope
sessionScope
applicationScope
param
paramValues
Header
headerValues
cookie
initParam
EL存取器
存取器用来检索对象的特性或集合的元素。
存取器: 通过 "[]" 或 "." 符号获取相关数据
例:${userBean.suser}
//获取输出bean中的suser属性值;
${mcType[“id”]} //获取map中key为id对应的值;
EL运算符
运算符允许对数据和文字进行组合以及比较。
EL运算符:
类别
算术运算符
关系运算符
逻辑运算符
验证运算符
验证运算符(empty):对于验证数据特别有用。empty 运算符采用单个表达式作为其变量(也即,${empty input}),并返回一个布尔值,该布尔值表示对表达式求值的结果是不是“空”值。求值结果为 null 的表达式被认为是空,即无元素的集合或数组。如果参数是对长度为零的 String 求值所得的结果,则 empty 运算符也将返回 true。
EL文字
文字表示固定的值 — 数字、字符、字符串、布尔型或空值。
在 EL 表达式中,数字、字符串、布尔值和 null 都可以被指定为文字值。字符串可以用单引号或双引号定界。布尔值被指定为 true 和 false
JSTL是什么
JSTL(JSP Standard Tag Library,JSP标准标签库)是一个不断完善的开放源代码的JSP标签库,是由apache的jakarta小组来维护的。JSTL1.0 由四个定制标记库(core、format、xml 和 sql)和一对通用标记库验证器组成。core 标记库提供了定制操作,通过限制了作用域的变量管理数据,以及执行页面内容的迭代和条件操作。它还提供了用来生成和操作 URL 的标记。format 标记库定义了用来格式化数据(尤其是数字和日期)的操作。它还支持使用本地化资源束进行JSP页面的国际化。xml 库包含一些标记,这些标记用来操作通过XML表示的数据,而 sql 库定义了用来查询关系数据库的操作。 两个 JSTL 标记库验证器允许开发人员在其 JSP 应用程序中强制使用编码标准。
注意:1.如果要使用JSTL,则必须引用jstl.jar和 standard.jar两个包。
2.还要在jsp页面中引用标签库:<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
jstl中最重要的两个标签就是if和forEach,只要使用jstl基本上都会要用到这两个标签
使用if标签: 只有if没有else
<span style="font-size:14px;"><span style="white-space:pre"> </span><c:forEach items="${list} }" var="p" varStatus="vs">
<c:if test="${vs.index%2==0} ">
<div><font color="red">${p.id} ${p.uname } ${p.address.province } ${p.address.city }</font></div>
</c:if>
<c:if test="${vs.index%2==1 }">
<div><font color="black">${p.id} ${p.uname } ${p.address.province } ${p.address.city }</font></div>
</c:if>
</c:forEach></span>
使用foeEach标签: 可以嵌套循环
<span style="font-size:14px;"><span style="white-space:pre"> </span><c:forEach items="${map }" var="cls">
<div>${cls.key }</div>
<c:forEach items="${cls.value }" var="p">
<div> ${p.id} ${p.uname } ${p.address.province } ${p.address.city }</div>
</c:forEach>
</c:forEach></span>