掌握 EL+jstl 用法

一、EL表达式

1. 概念:

Expression Language 表达式语言

2. 作用:

替换和简化jsp页面中java代码的编写

3. 语法:

${表达式}

4. 注意:

jsp默认支持el表达式的。如果要忽略el表达式

  1. 设置jsp中page指令中:isELIgnored="true" 忽略当前jsp页面中所有的el表达式
  2. \${表达式} :忽略当前这个el表达式

5. 使用:

1. 运算:

运算符:

  1. 算数运算符: + - * /(div) %(mod)
  2. 比较运算符: > < >= <= == !=
  3. 逻辑运算符: &&(and) ||(or) !(not)
  4. 空运算符: empty
    功能:用于判断字符串、集合、数组对象是否为null或者长度是否为0
 ${empty list}:判断字符串、集合、数组对象是否为null或者长度为0
 ${not empty str}:表示判断字符串、集合、数组对象是否不为null 并且 长度>0
2. 获取值
  1. el表达式只能从域对象中获取值
  2. 语法:
    ${域名称.键名}:从指定域中获取指定键的值

域名称:

  1. pageScope --> pageContext 当前页面
  2. requestScope --> request 一次请求
  3. sessionScope --> session 当前会话
  4. applicationScope --> application(ServletContext)全局,所有用户共享
举例:在request域中存储了name=张三
获取:${requestScope.name}
  1. ${键名}:
    表示依次从最小的域中查找是否有该键对应的值,直到找到为止。

  2. 获取对象、List集合、Map集合的值

    1. 对象:
      ${域名称.键名.属性名} 本质上会去调用对象的getter方法

    2. List集合:
      ${域名称.键名[索引]}

    3. Map集合:
      1. ${域名称.键名.key名称}
      2. ${域名称.键名[“key名称”]}

  3. 隐式对象:
    el表达式中有11个隐式对象
    request,response,outpageContext, session,applicationpage,config,exception

pageContext:获取jsp其他八个内置对象
例子:

 ${pageContext.request.contextPath}:动态获取虚拟目录

二、JSTL

1. 概念:

JavaServer Pages Tag Library JSP标准标签库 是由Apache组织提供的开源的免费的jsp标签 <标签>

2. 作用:

用于简化和替换jsp页面上的java代码

3. jstl 使用步骤:

  1. 导入jstl相关jar包
    提取码: shjm
    在这里插入图片描述
  2. 引入标签库:taglib指令: <%@ taglib %>
<%--引用标签库--%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

4. 常用的JSTL标签

1. if:相当于java代码的if语句
  1. 属性:test 必须属性,接受boolean表达式如果表达式为true,则显示if标签体内容,如果为false,则不显示标签体内容一般情况下,test属性值会结合el表达式一起使用
  2. 注意
    c:if标签没有else情况,想要else情况,则可以在定义一个c:if标签

实例

<%@ page import="java.util.List" %>
<%@ page import="java.util.ArrayList" %>
<%@ page contentType="text/html;charset=UTF-8" language="java"   isELIgnored="false" %>
<%--引用标签库--%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>if标签</title>
</head>
<body>
<c:if test="true">
    我是真的
</c:if>
<%--java--%>
<%
    List list=new ArrayList();
    list.add("aaaa");
    request.setAttribute("list",list);

    request.setAttribute("number",9);
%>
<%--jstl代码块--%>
<c:if test="${not empty list}">
遍历循环。。。。。。。。。。。。。。。。
</c:if>

<c:if test="${number%2!=0}">
    ${number}为基数
</c:if>
<%--c:if标签没有else情况,想要else情况,则可以在定义一个c:if标签--%>
<c:if test="${number%2==0}">
    ${number}为基数
</c:if>
</body>
</html>

2. choose:相当于java代码的switch语句
1. 使用choose标签声明         			相当于switch声明
2. 使用when标签做判断         			相当于case
3. 使用otherwise标签做其他情况的声明    	相当于default

实例

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>choose标签</title>
</head>
<body>
<%--choose:相当于java代码的switch语句--%>
<%--1. 使用choose标签声明         			相当于switch声明--%>
<%--2. 使用when标签做判断         			相当于case--%>
<%--3. 使用otherwise标签做其他情况的声明    	相当于default--%>
<%
    request.setAttribute("number",3);
%>

<c:choose>
    <c:when test="${number==1}">星期一</c:when>
    <c:when test="${number==2}">星期二</c:when>
    <c:when test="${number==3}">星期三</c:when>
    <c:when test="${number==4}">星期四</c:when>
    <c:when test="${number==5}">星期五</c:when>
    <c:when test="${number==6}">星期六</c:when>
    <c:when test="${number==7}">星期日</c:when>
    <c:otherwise>不符合规则</c:otherwise>
</c:choose>
</body>
</html>

3. foreach:相当于java代码的for语句
<%@ page import="java.util.List" %>
<%@ page import="java.util.ArrayList" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>foreach标签</title>
</head>
<body>

<%--
for(int i=0 ;i<=6;i++){

}
var 临时变量----> i
begin 开始 -----> int i=0
end 结束   -----> i<=6
step 步长  -----> i++
varStatus循环状态对象
    index 容器中元素的索引,从0开始
    count 循环次数
--%>
<c:forEach begin="1" end="6" var="i" step="1">
    ${i}
</c:forEach>

<hr>
<%--
for(int i:list ){

}
items:容器对象  --->list
var 容器中元素的临时变量----->i
varStatus循环状态对象
    index 容器中元素的索引,从0开始
    count 循环次数,1开始
--%>
<%
    List list=new ArrayList();
    list.add("aaa");
    list.add("bbb");

    request.setAttribute("list",list);
%>
<c:forEach items="${list}" var="str" varStatus="s">
    ${s.index} ${s.count} ${str}} <br>

</c:forEach>
</body>
</html>

三、 练习:

需求:在request域中有一个存有User对象的List集合。需要使用jstl+el将list集合数据展示到jsp页面的表格table中

javaBean类

import java.text.SimpleDateFormat;
import java.util.Date;
public class User {
    private String name;
    private int age;
    private Date data;
    //格式化日期
    public String getBirStr(){
        if ( data!=null){
            SimpleDateFormat spm=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
            return spm.format(data);
        }else {
            return "";
        }
    }
    //构造方法
    public User() {
    }
    public User(String name, int age,Date data) {
        this.name = name;
        this.age = age;
        this.data = data;
    }
	//get set 方法
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public Date getData() {
        return data;
    }
    public void setData(Date data) {
        this.data = data;
    }
}

jsp代码

<%@ page import="java.util.List" %>
<%@ page import="java.util.ArrayList" %>

<%@ page import="java.util.Date" %>
<%@ page import="cn.itcast.javaBean.User" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%
    List list=new ArrayList();
    list.add(new User("张三",19,new Date()));
    list.add(new User("李四",20,new Date()));
    list.add(new User("王五",21,new Date()));
    list.add(new User("赵六",21,new Date()));


    request.setAttribute("list",list);
%>
        <table style="color: aquamarine" width="400px" border="1px" align="center">
            <tr>
                <th>编号</th>
                <th>名字</th>
                <th>年龄</th>
                <th>出生日期</th>

            </tr>

        <c:forEach items="${list}" var="i" varStatus="s">
            <c:if test="${s.count% 2== 0}">
                <tr style="background-color: lightpink">
                    <td>${s.count}</td>
                    <td>${i.name}</td>
                    <td>${i.age}</td>
                    <td>${i.BirStr}</td>
                </tr>
            </c:if>
            <c:if test="${s.count% 2!= 0}">
                <tr style="background-color: cornflowerblue">
                    <td>${s.count}</td>
                    <td>${i.name}</td>
                    <td>${i.age}</td>
                    <td>${i.birStr}</td>
                </tr>
            </c:if>

        </c:forEach>
        </table>
</body>
</html>

浏览器出现效果
在这里插入图片描述
在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章