day49

1.EL 表达式

a)什么是 EL 表达式,EL 表达式的作用?

EL 表达式的全称是:Expression Language。是表达式语言。

EL 表达式的什么作用:EL 表达式主要是代替 jsp 页面中的表达式脚本在 jsp 页面中进行数据的输出。

因为 EL 表达式在输出数据的时候,要比 jsp 的表达式脚本要简洁很多。

EL 表达式的格式是:${表达式}

EL 表达式在输出 null 值的时候,输出的是空串。jsp 表达式脚本输出 null 值的时候,输出的是 null 字符串。

b)EL 表达式搜索域数据的顺序

EL 表达式主要是在 jsp 页面中输出数据。

主要是输出域对象中的数据。

当四个域中都有相同的 key 的数据的时候,EL 表达式会按照四个域的从小到大的顺序去进行搜索,找到就输出。

c)EL 表达式——运算

语法:${ 运算表达式 } , EL 表达式支持如下运算符:

1)关系运算

关系运算符

说明

范例

结果

== 或 eq

等于

${ 5 == 5 } 或 ${ 5 eq 5 }

true

!= 或 ne

不等于

${ 5 !=5 } 或 ${ 5 ne 5 }

false

< 或 lt

小于

${ 3 < 5 } 或 ${ 3 lt 5 }

true

> 或 gt

大于

${ 2 > 10 } 或 ${ 2 gt 10 }

false

<= 或 le

小于等于

${ 5 <= 12 } 或 ${ 5 le 12 }

true

>= 或 ge

大于等于

${ 3 >= 5 } 或 ${ 3 ge 5 }

false

2)逻辑运算

3)算数运算

i. empty 运算

empty 运算可以判断一个数据是否为空,如果为空,则输出 true,不为空输出 false。

以下几种情况为空:

1、值为 null 值的时候,为空

2、值为空串的时候,为空

3、值是 Object 类型数组,长度为零的时候

4、list 集合,元素个数为零

5、map 集合,元素个数为零

body>

<%

// 1、值为 null 值的时候,为空

request.setAttribute("emptyNull", null);

// 2、值为空串的时候,为空

request.setAttribute("emptyStr", "");

// 3、值是 Object 类型数组,长度为零的时候

request.setAttribute("emptyArr", new Object[]{});

// 4list 集合,元素个数为零

List<String> list = new ArrayList<>();

// list.add("abc");

request.setAttribute("emptyList", list);

// 5map 集合,元素个数为零

Map<String,Object> map = new HashMap<String, Object>();

// map.put("key1", "value1");

request.setAttribute("emptyMap", map);

%>

${ empty emptyNull } <br/>

${ empty emptyStr } <br/>

${ empty emptyArr } <br/>

${ empty emptyList } <br/>

${ empty emptyMap } <br/>

</body>

ii. 三元运算

表达式 1?表达式 2:表达式 3

如果表达式 1 的值为真,返回表达式 2 的值,如果表达式 1 的值为假,返回表达式 3 的值。示例:

${ 12 != 12 ? "哥帅呆":"哥又骗人" }

iii. “.点运算 和 [] 中括号运算符

.点运算,可以输出 Bean 对象中某个属性的值。

[]中括号运算,可以输出有序集合中某个元素的值。

并且[]中括号运算,还可以输出 map 集合中 key 里含有特殊字符的 key 的值。

<body>

<%

Map<String,Object> map = new HashMap<String, Object>();

map.put("a.a.a", "aaaValue");

map.put("b+b+b", "bbbValue");

map.put("c-c-c", "cccValue");

request.setAttribute("map", map);

%>

${ map['a.a.a'] } <br>

${ map["b+b+b"] } <br>

${ map['c-c-c'] } <br>

</body>

d)EL 表达式的 11 个隐含对象

EL 个达式中 11 个隐含对象,是 EL 表达式中自己定义的,可以直接使用。

变量                         类型                                 作用

pageContext               PageContextImpl           它可以获取 jsp 中的九大内置对象

pageScope                 Map<String,Object>        它可以获取 pageContext 域中的数据

requestScope               Map<String,Object>        它可以获取 Request 域中的数据

sessionScope               Map<String,Object>    它可以获取 Session 域中的数据

applicationScope            Map<String,Object>   它可以获取 ServletContext 域中的数据

param                    Map<String,String>     它可以获取请求参数的值

paramValues       Map<String,String[]>  它也可以获取请求参数的值,获取多个值的时候使用。

header                   Map<String,String>   它可以获取请求头的信息

headerValues        Map<String,String[]>  它可以获取请求头的信息,它可以获取多个值的情况

cookie              Map<String,Cookie>   它可以获取当前请求的 Cookie 信息

initParam     Map<String,String> 它可以获取在 web.xml 中配置的<context-param>上下文参数

i. EL 获取四个特定域中的属性

pageScope     ======   pageContext 域

requestScope   ======   Request 域

sessionScope    ======    Session 域

applicationScope  ======  ServletContext 域

ii. pageContext 对象的使用

1. 协议:

2. 服务器 ip:

3. 服务器端口:

4. 获取工程路径:

5. 获取请求方法:

6. 获取客户端 ip 地址:

7. 获取会话的 id 编号:

<body>

<%--

request.getScheme() 它可以获取请求的协议

request.getServerName() 获取请求的服务器 ip 或域名

request.getServerPort() 获取请求的服务器端口号

getContextPath() 获取当前工程路径

request.getMethod() 获取请求的方式(

GET POST

request.getRemoteHost() 获取客户端的 ip 地址

session.getId() 获取会话的唯一标识

--%>

<%

pageContext.setAttribute("req", request);

%>

<%=request.getScheme() %> <br>1.协议: ${ req.scheme }<br>

2.服务器 ip:${ pageContext.request.serverName }<br>

3.服务器端口:${ pageContext.request.serverPort }<br>

4.获取工程路径:${ pageContext.request.contextPath }<br>

5.获取请求方法:${ pageContext.request.method }<br>

6.获取客户端 ip 地址:${ pageContext.request.remoteHost }<br>

7.获取会话的 id 编号:${ pageContext.session.id }<br>

</body>

iii. EL 表达式其他隐含对象的使用

param        Map<String,String>    它可以获取请求参数的值

paramValues   Map<String,String[]>   它也可以获取请求参数的值,获取多个值的时候使用。

输出请求参数 username 的值:${ param.username } <br>

输出请求参数 password 的值:${ param.password } <br>

输出请求参数 username 的值:${ paramValues.username[0] } <br>

输出请求参数 hobby 的值:${ paramValues.hobby[0] } <br>

输出请求参数 hobby 的值:${ paramValues.hobby[1] } <br>

请求地址:

http://localhost:8080/demo03/a.jsp?username=mark&password=666666&hobby=java&hobby=php 

header        Map<String,String>     它可以获取请求头的信息

headerValues   Map<String,String[]>    它可以获取请求头的信息,它可以获取多个值的情况

输出请求头【User-Agent】的值:${ header['User-Agent'] } <br>

输出请求头【Connection】的值:${ header.Connection } <br>

输出请求头【User-Agent】的值:${ headerValues['User-Agent'][0] } <br>

cookie    Map<String,Cookie>    它可以获取当前请求的 Cookie 信息

获取 Cookie 的名称:${ cookie.JSESSIONID.name } <br>

获取 Cookie 的值:${ cookie.JSESSIONID.value } <br>

initParam   Map<String,String>   它可以获取在 web.xml 中配置的<context-param>上下文参数

web.xml 中的配置:

<context-param>

<param-name>username</param-name>

<param-value>root</param-value>

</context-param>

<context-param>

<param-name>url</param-name>

<param-value>jdbc:mysql:///test</param-value>

</context-param>

输出<Context-param>username 的值:${ initParam.username } <br>

输出<Context-param>url 的值:${ initParam.url } <br>

2JSTL 标签库

JSTL 标签库 全称是指 JSP Standard Tag Library JSP 标准标签库。是一个不断完善的开放源代码的 JSP 标签库。

EL 表达式主要是为了替换 jsp 中的表达式脚本,而标签库则是为了替换代码脚本。这样使得整个 jsp 页面变得更佳简洁。

JSTL 由五个不同功能的标签库组成。

在 jsp 标签库中使用 taglib 指令引入标签库

CORE 标签库

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

XML 标签库<%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml" %>

FMT 标签库

<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>

SQL 标签库

<%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>

FUNCTIONS 标签库

<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>

e) JSTL 标签库的使用步骤

1、先导入 jstl 标签库的 jar 包。

jstl-1.2.jar

2、第二步,使用 taglib 指令引入标签库。

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

f)core 核心库使用

i. <c:set />(使用很少)

作用:set 标签可以往域中保存数据

<%--

i.<c:set />

作用:set 标签可以往域中保存数据

域对象.setAttribute(key,value);

scope 属性设置保存到哪个域

page 表示 PageContext 域(默认值)

request 表示 Request

session 表示 Session

application 表示 ServletContext

var 属性设置 key 是多少

value 属性设置值

--%>

保存之前:${ sessionScope.abc } <br>

<c:set scope="session" var="abc" value="abcValue"/>

保存之后:${ sessionScope.abc } <br>

ii. <c:if />

if 标签用来做 if 判断。

<%--

ii.<c:if />

if 标签用来做 if 判断。

test 属性表示判断的条件(使用 EL 表达式输出)

--%>

<c:if test="${ 12 == 12 }">

<h1>12 等于 12</h1>

</c:if>

<c:if test="${ 12 != 12 }">

<h1>12 不等于 12</h1>

</c:if>

iii. <c:choose> <c:when> <c:otherwise>标签

作用:多路判断。跟 switch ... case .... default 非常接近

<%--

iii.<c:choose> <c:when> <c:otherwise>标签

作用:多路判断。跟 switch ... case .... default 非常接近

choose 标签开始选择判断

when 标签表示每一种判断情况

test 属性表示当前这种判断情况的值

otherwise 标签表示剩下的情况

<c:choose> <c:when> <c:otherwise>标签使用时需要注意的点:

1、标签里不能使用 html 注释,要使用 jsp 注释

2when 标签的父标签一定要是 choose 标签

--%>

<%

request.setAttribute("height", 180);

%>

<c:choose>

<%-- 这是 html 注释 --%>

<c:when test="${ requestScope.height > 190 }">

<h2>小巨人</h2>

</c:when>

<c:when test="${ requestScope.height > 180 }">

<h2>很高</h2>

</c:when>

<c:when test="${ requestScope.height > 170 }">

<h2>还可以</h2>

</c:when><c:otherwise>

<c:choose>

<c:when test="${requestScope.height > 160}">

<h3>大于 160</h3>

</c:when>

<c:when test="${requestScope.height > 150}">

<h3>大于 150</h3>

</c:when>

<c:when test="${requestScope.height > 140}">

<h3>大于 140</h3>

</c:when>

<c:otherwise>

其他小于 140

</c:otherwise>

</c:choose>

</c:otherwise>

</c:choose>

iv. <c:forEach />

作用:遍历输出使用。

1. 遍历 1 10,输出

示例代码:

<%--1.遍历 1 10,输出

begin 属性设置开始的索引

end 属性设置结束的索引

var 属性表示循环的变量(也是当前正在遍历到的数据)

for (int i = 1; i < 10; i++)

--%>

<table border="1">

<c:forEach begin="1" end="10" var="i">

<tr>

<td>第${i}行</td>

</tr>

</c:forEach>

</table>

2. 遍历 Object 数组

示例代码:

<%-- 2.遍历 Object 数组

for (Object item: arr)

items 表示遍历的数据源(遍历的集合)

var 表示当前遍历到的数据

--%>

<%

request.setAttribute("arr", new String[]{"18610541354","18688886666","18699998888"});

%>

<c:forEach items="${ requestScope.arr }" var="item">

${ item } <br>

</c:forEach>

3. 遍历 Map 集合

示例代码:

<%

Map<String,Object> map = new HashMap<String, Object>();

map.put("key1", "value1");

map.put("key2", "value2");

map.put("key3", "value3");

//

for ( Map.Entry<String,Object> entry : map.entrySet()) {

//

}

request.setAttribute("map", map);

%>

<c:forEach items="${ requestScope.map }" var="entry">

<h1>${entry.key} = ${entry.value}</h1>

</c:forEach>

4. 遍历 List 集合---list 中存放 Student 类,有属性:编号,用户名,密码,年龄,电话信息

Student 类:

public class Student {

//4.编号,用户名,密码,年龄,电话信息

private Integer id;

private String username;

private String password;

private Integer age;

private String phone;

示例代码:<%--4.遍历 List 集合---list 中存放 Student 类,有属性:编号,用户名,密码,年龄,电话信息--%>

<%

List<Student> studentList = new ArrayList<Student>();

for (int i = 1; i <= 10; i++) {

studentList.add(new Student(i,"username"+i ,"pass"+i,18+i,"phone"+i));

}

request.setAttribute("stus", studentList);

%>

<table>

<tr>

<th>编号</th>

<th>用户名</th>

<th>密码</th>

<th>年龄</th>

<th>电话</th>

<th>操作</th>

</tr>

<%--

items 表示遍历的集合

var 表示遍历到的数据

begin 表示遍历的开始索引值

end 表示结束的索引值

step 属性表示遍历的步长值

varStatus 属性表示当前遍历到的数据的状态  

        Index  下标索引

        Count   第几个元素

        First   是否是第一个

        Last   是否是最后一个

        

forint i = 1; i < 10; i+=2

--%>

<c:forEach begin="2" end="7" step="2" varStatus="status" items="${requestScope.stus}" var="stu">

<tr>

<td>${stu.id}</td>

<td>${stu.username}</td>

<td>${stu.password}</td>

<td>${stu.age}</td>

<td>${stu.phone}</td>

<td>${status.step}</td>

</tr>

</c:forEach>

</table>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值