EL - Expression LanguageBasic Concept
EL 表达式供应了在 JSP 中简化表达式的方法,可以方便地访问各种数据并输出。
Main Function依次访问 pageContext、request、session 和 application 浸染域工具存储的数据。
获取要求参数值。
访问 Bean 工具的属性。
访问凑集中的数据。
输出大略的运算结果。
访问内置工具的数据<%= request.getAttribute(“varName”) %> 用 EL 实现:${ varName }
访问要求参数的数据在 EL 之前利用下列办法访问要求参数的数据
request.getParameter(name);request.getParameterValues(name);
在 EL 中利用下列办法访问要求参数的数据
param:吸收的参数只有一个值。
paramValues:接管的参数有多个值。
<!-- 获取指定参数的数值 -->${param.name}<!-- 获取指定参数中指定下标的数值 -->${paramValues.hobby[0]}
访问 Bean 工具的属性访问办法
办法一: ${工具名.属性名},例如:${user.name} 办法二: ${工具名[“属性名”]},例如:${user[34;name"]}
紧张差异当要存取的属性名中包含一些分外字符,如: . 或 , 等并非字母或数字的符号,就一定要利用 [] 而不是 . 的办法。
利用 [] 的办法可以动态取值,详细办法如下:
<% Person person = new Person(); person.setName("zhangfei"); person.setAge(30); pageContext.setAttribute("person", person); pageContext.setAttribute("var1", "name"); pageContext.setAttribute("var2", "age");%>获取到的姓名是:${person.name}<br/>获取到的年事是:${person.age}<br/>获取到的姓名是:${person["name"]}<br/>获取到的年事是:${person["age"]}<br/>动态取值的结果为:${person[var1]}
访问凑集中的数据
<% // 准备一个 List 凑集并添加数据内容 List<String> list = new LinkedList<>(); list.add("two"); list.add("one"); list.add("three"); // 将全体凑集放入指定的内置工具中 pageContext.setAttribute("list", list); // 准备一个 Map 凑集并添加数据 Map<String, Integer> map = new HashMap<>(); map.put("one", 1); map.put("two", 2); map.put("th.ree", 3); // 将全体凑集放入指定的内置工具中 pageContext.setAttribute("map", map);%><%-- 利用 EL 表达式实现凑集中数据内容的获取 --%>凑集中下标为 0 的元素是:${list[0]}<br/> <%-- two --%>凑集中下标为 1 的元素是:${list[1]}<br/> <%-- one --%>凑集中下标为 2 的元素是:${list[2]}<br/> <%-- three --%><hr/><%-- 利用 EL 表达式实现 Map 凑集中数据内容的获取,不支持下标 --%>全体 Map 凑集中的元素有:${map}<br/>获取带有分外字符 key 对应的数值为:${map["th.ree"]}<br/> <%-- 3 --%>
常用的内置工具JSP
pageContext - 处理当前页面
浸染域pageScope - 同页面浸染域属性名称和值有关的 Map 类 requestScope - 同要求浸染域属性的名称和值有关的 Map 类 sessionScope - 同会话浸染域属性的名称和值有关的 Map 类 applicationScope - 同运用程序浸染域属性的名称和值有关的 Map 类
要求参数param - 根据名称存储要求参数的值的 Map 类 paramValues - 把要求参数的所有值作为一个 String 数组来存储的 Map 类
要求头header - 根据名称存储要求头紧张值的 Map 类 headerValues - 把要求头的所有值作为一个 String 数组来存储的 Map 类
Cookiecookie - 根据名称存储要求附带的 cookie 的 Map 类
初始化参数initParam - 根据名称存储 Web 运用程序高下文初始化参数的 Map 类
常用的运算符<% // 通过内置工具设置属性的办法来准备操作数 request.setAttribute("ia", 5); request.setAttribute("ib", 2); request.setAttribute("b1", true); request.setAttribute("b2", false);%><%-- 实现上述所有操作数的获取和打印 --%>ia 的数值为:${ia}<br/> <%-- 5 --%>ib 的数值为:${ib}<br/> <%-- 2 --%>b1 的数值为:${b1}<br/> <%-- true --%>b2 的数值为:${b2}<br/> <%-- false --%>
算术运算符
<%-- 实现算术运算符的利用 --%>ia+ib 的结果为:${ia+ib}<br/> <%-- 7 --%>ia-ib 的结果为:${ia-ib}<br/> <%-- 3 --%>iaib 的结果为:${iaib}<br/> <%-- 10 --%>ia/ib 的结果为:${ia/ib}<br/> <%-- 2.5 --%>ia%ib 的结果为:${ia%ib}<br/> <%-- 1 --%>
关系运算符
<%-- 实现关系运算符的利用 --%>ia 大于 ib 的结果为:${ia > ib}<br/> <%-- true --%>ia 大于即是 ib 的结果为:${ia >= ib}<br/> <%-- true --%>ia 小于 ib 的结果为:${ia < ib}<br/> <%-- false --%>ia 小于即是 ib 的结果为:${ia <= ib}<br/> <%-- false --%>ia 即是 ib 的结果为:${ia == ib}<br/> <%-- false --%>ia 不即是 ib 的结果为:${ia != ib}<br/> <%-- true --%>
逻辑运算符
<%-- 实现逻辑运算符的利用 --%>b1 并且 b2 的结果为:${b1 && b2}<br/> <%-- false --%>b1 或者 b2 的结果为:${b1 || b2}<br/> <%-- true --%>b1 取反的结果为:${ !b1 }<br/> <%-- false --%>b2 取反的结果为:${ !b2 }<br/> <%-- true --%>
条件运算符和验证运算符
Null 值、无元素的凑集或数组、长度为零的 String 都被认为是空值。
<% String str1 = null; String str2 = ""; String str3 = "hello"; List<Integer> list1 = new LinkedList<>(); List<Integer> list2 = Arrays.asList(11, 22, 33, 44, 55); request.setAttribute("str1", str1); request.setAttribute("str2", str2); request.setAttribute("str3", str3); request.setAttribute("list1", list1); request.setAttribute("list2", list2);%><%-- 实现条件运算符和验证运算符的利用 --%>ia 和 ib 之间的最大值为:${ia>ib ? ia : ib}<br/>判断是否为空的结果是:${empty str1}<br/> <%-- true --%>判断是否为空的结果是:${empty str2}<br/> <%-- true --%>判断是否为空的结果是:${empty str3}<br/> <%-- false --%>判断是否为空的结果是:${empty list1}<br/> <%-- true --%>判断是否为空的结果是:${empty list2}<br/> <%-- false --%>
JSTL 被称为 JSP 标准标签库。 开拓职员可以利用这些标签取代 JSP 页面上的 Java 代码,从而提高程序的可读性,降落程序的掩护难度。
How to Use JSTL下载 JSTL 的 jar 包并添加到项目中,下载地址为:https://tomcat.apache.org/download-taglibs.cgi
在JSP页面中利用 taglib 指定引入 JSTL 标签库:
<!-- prefix 属性用于指定库前缀 --><!-- uri 属性用于指定库的标识 --><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
Core Tags常用核心标签输出标签
用来将指定内容输出的标签
<c:out value="Hello World"></c:out>
设置标签
用来设置属性范围值的标签
<%-- pageContext.setAttibute("name", "zhangfei") --%><c:set var="name" value="zhangfei" scope="page"></c:set><c:out value="${name}"></c:out><%-- 设置一个工具的属性值并打印出来 --%><jsp:useBean id="person" class="com.renda.Person" scope="page"></jsp:useBean><c:set property="name" value="guanyu" target="${person}"></c:set><c:set property="age" value="35" target="${person}"></c:set><c:out value="${person.name}"></c:out><c:out value="${person.age}"></c:out>
删除标签
用来删除指天命据的标签
<c:remove var="name" scope="page"></c:remove><c:out value="${name}" default="无"></c:out>
单条件判断标签
<c:set var="age" value="17" scope="page"></c:set><c:out value="${age}"></c:out><c:if test="${age >= 18}"> <c:out value="已经成年"></c:out></c:if>
多条件判断标签
<c:set var="score" value="59" scope="page"></c:set><c:out value="${score}"></c:out><c:choose> <c:when test="${score > 60}"> <c:out value="成绩合格"></c:out> </c:when> <c:when test="${score == 60}"> <c:out value="刚好合格"></c:out> </c:when> <c:otherwise> <c:out value="成绩不合格"></c:out> </c:otherwise></c:choose>
循环标签
<% // 准备一个数组并初始化 String[] sArr = {"11", "22", "33", "44", "55"}; pageContext.setAttribute("sArr", sArr);%><%-- 利用循环标签遍历数组中的所有元素 --%><c:forEach var="ts" items="${sArr}"> <c:out value="${ts}"></c:out></c:forEach><%-- 跳跃性遍历。间隔为 2 --%><c:forEach var="ts" items="${sArr}" step="2"> <c:out value="${ts}"></c:out></c:forEach><%-- 指定起始和结尾位置。包含 1 和 3 --%><c:forEach var="ts" items="${sArr}" begin="1" end="3"> <c:out value="${ts}"></c:out></c:forEach>
Function Tags
常用函数标签
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %><% pageContext.setAttribute("var", "HelloWorld");%>原始字符串为:${var}<br/> <%-- HelloWorld --%>判断该字符串是否包含指定字符串的结果为:${fn:contains(var, "Hello")}<br/> <%-- true --%>将字符串中所有字符转换为大写的结果为:${fn:toUpperCase(var)}<br/> <%-- HELLOWORLD--%>将字符串中所有字符转换为小写的结果为:${fn:toLowerCase(var)}<br/> <%-- helloworld --%>
Formatting Tags
常用格式化标签
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %><% // 获取当前系统韶光 Date date = new Date(); pageContext.setAttribute("date", date);%>当前系统韶光为:${date}格式化后的韶光:<fmt:formatDate value="${date}" pattern="yyyy-MM-dd HH:mm:ss"></fmt:formatDate>
JSP Custom Tags
如果上面几个标签不能知足需求,程序员也可以自定义标签。步骤如下。
编写标签类继续 SimpleTagSupport 类或 TagSupport 类并重写 doTag 方法或 doStartTag 方法。public class HelloTag extends SimpleTagSupport { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public void doTag() throws JspException, IOException { JspWriter out = this.getJspContext().getOut(); out.println("自定义标签的参数为:" + name); }}
定义标签库文件(tld 标签库文件)并配置标签解释文件到到 WEB-INF 目录下。
<taglib xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd" version="2.1"> <tlib-version>1.0</tlib-version> <short-name>my</short-name> <uri>http://renda.com</uri> <!-- Invoke 'Generate' action to add tags or functions --> <tag> <name>hello</name> <tag-class>com.renda.HelloTag</tag-class> <body-content>empty</body-content> <attribute> <name>name</name> <required>true</required> </attribute> </tag></taglib>
在 JSP 中添加 taglib 指令引入标签库利用:
<%@ taglib prefix="my" uri="http://renda.com" %><my:hello name="David"/>
想理解更多,欢迎关注我的微信公众年夜众号:Renda_Zhang