JavaWeb EL 表达式 & JSTL 标签库

1.EL 表达式

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

     EL 表达式的全称是: Expression
     Language 。是表达式语言。
     EL 表达式的什么作用: EL 表达式主要是代替 jsp 页面中的表达式脚本在 jsp 页面中进行数据的输出。
     因为 EL 表达式在输出数据的时候,要比 jsp 的表达式脚本要简洁很多。
<body>
    <%
        request.setAttribute("key","值");
    %>
    表达式脚本输出 key 的值是:
    <%=request.getAttribute("key1")==null?"":request.getAttribute("key1")%><br/>
    EL 表达式输出 key 的值是:${key1}
</body>
</html>
   EL 表达式的格式是: ${ 表达式 }
   EL 表达式在输出 null 值的时候,输出的是空串。 jsp 表达式脚本输出 null 值的时候,输出的是 null 字符串。

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

   EL 表达式主要是在 jsp 页面中输出数据。
  主要是输出域对象中的数据。
 
  当四个域中都有相同的 key 的数据的时候, EL 表达式会按照四个域的从小到大的顺序去进行搜索,找到就输出。
<body>
    <%
        //往四个域中都保存了相同的 key 的数据。
        pageContext.setAttribute("key","pageContext");
        request.setAttribute("key","request");
        session.setAttribute("key","session");
        application.setAttribute("key","application");
    %>
    ${ key }
</body>

c)EL 表达式输出 Bean 的普通属性,数组属性。List 集合属性,map 集合属性

     i.需求——输出 Person 类中普通属性,数组属性。 list 集合属性和 map 集合属性。
Perosn类:
public class Person {
    // i.需求——输出 Person 类中普通属性,数组属性。list 集合属性和 map 集合属性。
    private String name;
    private String[] phone;
    private List<String> cities;
    private Map<String,Object> map;

    public int getAge() {
        return 18;
    }

    public Person() {
    }

    public Person(String name, String[] phone, List<String> cities, Map<String, Object> map) {
        this.name = name;
        this.phone = phone;
        this.cities = cities;
        this.map = map;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String[] getPhone() {
        return phone;
    }

    public void setPhone(String[] phone) {
        this.phone = phone;
    }

    public List<String> getCities() {
        return cities;
    }

    public void setCities(List<String> cities) {
        this.cities = cities;
    }

    public Map<String, Object> getMap() {
        return map;
    }

    public void setMap(Map<String, Object> map) {
        this.map = map;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", phone=" + Arrays.toString(phone) +
                ", cities=" + cities +
                ", map=" + map +
                '}';
    }
}

输出的代码:

<body>
    <%
        Person person = new Person();
        person.setName("耗子尾汁!");
        person.setPhone(new String[]{"18610541354","18688886666","18699998888"});

        List<String> cities = new ArrayList<String>();
        cities.add("北京");
        cities.add("上海");
        cities.add("深圳");
        person.setCities(cities);

        Map<String,Object> map = new HashMap<>();
        map.put("key1","value1");
        map.put("key2","value2");
        map.put("key3","value3");
        person.setMap(map);

        pageContext.setAttribute("p",person);
    %>

    输出Person:${ p }<br/>
    输出Person的name属性:${p.name} <br>
    输出Person的pnones数组属性值:${p.phone[2]} <br>
    输出Person的cities集合中的元素值:${p.cities} <br>
    输出Person的List集合中个别元素值:${p.cities[2]} <br>
    输出Person的Map集合: ${p.map} <br>
    输出Person的Map集合中某个key的值: ${p.map.key3} <br>
    输出Person的age属性:${p.age} <br>

</body>

d)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

i. empty 运算

empty 运算可以判断一个数据是否为空,如果为空,则输出 true, 不为空输出 false
以下几种情况为空:
1 、值为 null 值的时候,为空
2 、值为空串的时候,为空
3 、值是 Object 类型数组,长度为零的时候
4 list 集合,元素个数为零
5 map 集合,元素个数为零
<body>
    <%
        //1、值为 null 值的时候,为空
        request.setAttribute("emptyNull",null);
        //2、值为空串的时候,为空
        request.setAttribute("emptyString","");
        //3、值是 Object 类型数组,长度为零的时候
        request.setAttribute("emptyArr",new Object[]{});
        //4、list 集合,元素个数为零
        List<String> list = new ArrayList<>();
        // list.add("abc");
        request.setAttribute("emptylist",list);
        //5、map 集合,元素个数为零
        Map<String,Object> map = new HashMap<String, Object>();
        //  map.put("key1","value1");
        request.setAttribute("emptyMap",map);
    %>
    ${ empty emptyNull } <br/>
    ${ empty emptyString } <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>

aaaValue
bbbvalue
cccvalue

e)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
<body>
    <%
        pageContext.setAttribute("key1","pageContext1");
        pageContext.setAttribute("key2","pageContext2");
        request.setAttribute("key2","request");
        session.setAttribute("key2","session");
        application.setAttribute("key2","application");
    %>
    ${ applicationScope.key2 }
</body>

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() %>
    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[]>                  它也可以获取请求参数的值,获取多个值的时候使用。
示例代码:
<body>
    输出请求参数 username 的值:${ param.username } <br>
    输出请求参数 password 的值:${ param.password } <br>
    输出请求参数 username 的值:${ paramValues.username[0] } <br>
    输出请求参数 hobby 的值:${ paramValues.hobby[0] } <br>
    输出请求参数 hobby 的值:${ paramValues.hobby[1] } <br>
</body>
请求地址:
http://localhost:8080/09_EL_JSTL/other_el_obj.jsp?username=wzg168&password=666666&hobby=java&hobby=cpp
 
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 中的配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">

    <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>
示例代码
输出&lt;Context-param&gt;username 的值:${ initParam.username } <br>
输出&lt;Context-param&gt;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" %>

f) JSTL 标签库的使用步骤

1 、先导入 jstl 标签库的 jar 包。
    taglibs-standard-impl-1.2.1.jar
    taglibs-standard-spec-1.2.1.jar
2 、第二步,使用 taglib 指令引入标签库
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

g)core 核心库使用

i. <c:set /> (使用很少)
    作用: set 标签可以往域中保存数据
<body>
    <%--
    i.<c:set />
    作用:set 标签可以往域中保存数据
    域对象.setAttribute(key,value);
    scope 属性设置保存到哪个域
        page 表示 PageContext 域(默认值)
        request 表示 Request 域
        session 表示 Session 域
        application 表示 ServletContext 域
    var 属性设置 key 是多少
    value属性设置值
    --%>
    保存之前:${ requestScope.abc } <br>
    <c:set scope="request" var="abc" value="abcValue"/>
    保存之后:${ requestScope.abc } <br>
</body>
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 注释
        2、when 标签的父标签一定要是 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 ,输出
示例代码:   
<body>
    <%--
    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>
</body>
  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;

    public Student() {
    }

    public Student(Integer id, String username, String password, Integer age, String phone) {
        this.id = id;
        this.username = username;
        this.password = password;
        this.age = age;
        this.phone = phone;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return username;
    }

    public void setName(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getPhone() {
        return phone;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }

    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", age=" + age +
                ", phone='" + 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 属性表示当前遍历到的数据的状态
            for(int 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.name}</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、付费专栏及课程。

余额充值