JavaWeb 速通 EL 和 JSTL

目录

一、EL表达式

        1.快速入门 : 

            1.1 基本介绍

            1.2 入门案例

        2.常用输出形式 : 

            2.1 创建JavaBean类

            2.2 创建JSP文件

        3.empty运算符 : 

            3.1 介绍

            3.2 实例

        4.EL对象 : 

            4.1 EL11个内置对象

            4.2 域对象演示

            4.3获取HTTP信息

二、JSTL标签库

        1.基本介绍 : 

        2.core核心库常用标签 : 

            2.1

            2.2

            2.3 

            2.4 /c:forEach>


一、EL表达式

        1.快速入门 : 

            1.1 基本介绍

         EL 表达式全称:Expression Language,是表达式语言
        EL 表达式的主要作用是代替JSP页面的表达式脚本 <%= request.getAttribute("...") %>

         EL 表达式基本语法: ${key},形式上比传统的JSP表达式脚本更简洁。

            1.2 入门案例

                以intro.jsp为例,代码如下 : 

<%--
    User : Cyan_RA9
    Version : 21.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>EL expression</title>
</head>
<body>
    <%
        request.setAttribute("color", "pink");
    %>
    <%--
        PS : 若attribute为null,取出数据时,JSP方式返回"null",而EL表达式返回"".
     --%>
    <h1>传统JSP取出数据———</h1>
    color : <%= request.getAttribute("color") %> <br/>
    author : <%= request.getAttribute("author") %> <br><hr> <%--可使用三元运算符优化--%>

    <h1>采用EL表达式取出数据———</h1>
    color : ${color} <br/>
    author : ${author}
</body>
</html>

                运行结果 : 

        2.常用输出形式 : 

            2.1 创建JavaBean类

                Movie类代码如下 : 

package el;

import java.util.List;
import java.util.Map;

/**
 * @author : Cyan_RA9
 * @version : 21.0
 * @what : 标准JavaBean类
 */
public class Movie {
    private String name;
    private int length;
    private List<String> platforms;
    private Map<String, String> comments;

    public Movie() {
    }

    public Movie(String name, int length, List<String> platforms, Map<String, String> comments) {
        this.name = name;
        this.length = length;
        this.platforms = platforms;
        this.comments = comments;
    }

    public String getName() {
        return name;
    }

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

    public int getLength() {
        return length;
    }

    public void setLength(int length) {
        this.length = length;
    }

    public List<String> getPlatforms() {
        return platforms;
    }

    public void setPlatforms(List<String> platforms) {
        this.platforms = platforms;
    }

    public Map<String, String> getComments() {
        return comments;
    }

    public void setComments(Map<String, String> comments) {
        this.comments = comments;
    }

    @Override
    public String toString() {
        return "Movie{" +
                "name='" + name + '\'' +
                ", length=" + length +
                ", platforms=" + platforms +
                ", comments=" + comments +
                '}';
    }
}

            2.2 创建JSP文件

                output.jsp文件代码如下 : 

<%@ page import="el.Movie" %>
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.HashMap" %><%--
    User : Cyan_RA9
    Version : 21.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>EL output</title>
</head>
<body>
    <h1>输出Movie对象的信息</h1>
    <%
        Movie movie = new Movie();
        movie.setName("Matrix");
        movie.setLength(150);

        ArrayList<String> platforms = new ArrayList<>();
        platforms.add("Bilibili");
        platforms.add("YouTube");
        platforms.add("Youku");
        movie.setPlatforms(platforms);

        HashMap<String, String> comments = new HashMap<>();
        comments.put("Cyan", "It's a so nice film!");
        comments.put("Rain", "I like it!");
        comments.put("Ice", "Pretty good!");
        movie.setComments(comments);

        //将movie对象放入request域对象中
        request.setAttribute("movie", movie);
    %>
    <%-- 取出数据 --%>
    Movie.name = ${movie.name} <br/>
    Movie.length = ${movie.length} <br/>

    Movie.platforms = ${movie.platforms} <br/>
    Movie.platforms[2] = ${movie.platforms[2]} <br/>
    Movie.platforms[2] = ${movie.platforms.get(2)} <br/>

    Movie.comments = ${movie.comments} <br/>
    Movie.comments_Cyan = ${movie.comments.get("Cyan")} <br/>
    Movie.comments_Rain = ${movie.comments["Rain"]} <br/>
</body>
</html>

                运行结果 : 

        3.empty运算符 : 

            3.1 介绍

         empty 运算可以判断一个数据是否为空,如果为空,返回true,否则返回false

        2° 以下几种情况为空——
          
● value = null
          ● value = ""
          ● value = new Object[] {} (长度为0的Object数组)
          ● 元素个数为0 的List集合
          ● 元素个数为0 的Map集合

            3.2 实例

                empty.jsp代码如下 : 

<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.HashMap" %><%--
    User : Cyan_RA9
    Version : 21.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>empty expression</title>
</head>
<body>
    <%
        request.setAttribute("key1", null);
        request.setAttribute("key2", "");
        request.setAttribute("key3", new Object[]{});
        request.setAttribute("key4", new ArrayList<>());
        request.setAttribute("key5", new HashMap<>());
    %>
    <%-- 判断是否为空 --%>
    key1是否为空: ${empty key1} <br/>
    key2是否为空: ${empty key2} <br/>
    key3是否为空: ${empty key3} <br/>
    key4是否为空: ${empty key4} <br/>
    key5是否为空: ${empty key5}
</body>
</html>

                运行结果 : 

        4.EL对象 : 

            4.1 EL11个内置对象

                如下表格所示 : 

变量类型说明
pageContextPageContextImpl获取JSP中的九大内置对象
pageScopeMap<String, Object>获取pageContext域中的数据
requestScopeMap<String, Object>获取request域中的数据
sessionScopeMap<String, Object>获取Session域中的数据
applicationScopeMap<String, Object>获取ServletContext域中的对象
paramMap<String, String>获取请求参数的值
paramValuesMap<String, String[]>获取多个值
headerMap<String, String>获取请求头的信息
headerValuesMap<String, String[]>获取请求头的多个信息
cookieMap<String, Cookie>获取当前请求的Cookie信息
initParamMap<String, String>获取在web.xml中配置的<context-param>上下文参数

            4.2 域对象演示

                elScope.jsp代码如下 : 

<%--
    User : Cyan_RA9
    Version : 21.0
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>EL scope</title>
</head>
<body>
    <%
        pageContext.setAttribute("color", "cyan");
        request.setAttribute("color", "pink");
        session.setAttribute("color", "cornflower_blue");
        application.setAttribute("color", "lightyellow");
    %>
    pageContext域_color = ${pageScope.color} <br/>
    request域_color = ${requestScope.color} <br/>
    session域_color = ${sessionScope.color} <br/>
    ServletContext域_color = ${applicationScope.color}
</body>
</html>

                运行结果 : 

            4.3获取HTTP信息

                http.jsp代码如下 : 

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>pageContext demo</title>
</head>
<body>
<h1>pageContext对象获取HTTP信息</h1>
<hr/>
<%  //简化形式(将request域对象放入pageContext域中)——— JSP
    pageContext.setAttribute("req", request);
%>
协议: ${ pageContext.request.scheme }<br>
协议: ${ req.scheme }<br>
服务器 ip:${ req.serverName }<br>
服务器端口:${ req.serverPort }<br>
工程路径:${ req.contextPath }<br>
请求方法:${ req.method }<br>
客户端 ip 地址:${ req.remoteHost }<br>
会话 id :${ pageContext.session.id }<br>
</body>
</html>

                运行结果 : 


二、JSTL标签库

        1.基本介绍 : 

         JSTL标签库是指 JSP Standard Tag Library,即JSP标准标签库。

        EL 表达式是为了替换JSP中的表达式脚本<%=%>, JSTL 是为了替换JSP中的代码脚本<%%>
        JSTL 由五个标签库组成——
功能范围URI前缀
核心标签库http://java.sun.com/jsp/jstl/corec
格式化http://java.sun.com/jsp/jstl/fmtfmt
函数http://java.sun.com/jsp/jstl/functionsfn
数据库(不使用http://java.sun.com/jsp/jstl/sqlsql
XML(不使用http://java.sun.com/jsp/jstl/xmlx

        使用JSTL需要导入jar包(impl 和 spec),PS : Tomcat10版本对jar包的依赖有变化(jakarta)导入jar包后要重新启动Tomcat。下载jar包的网址如下 : 

Apache Taglibs - Apache Standard Taglib: JSP[tm] Standard Tag Library (JSTL) implementations

         taglib引入标签,要放在行首

        2.core核心库常用标签 : 

            2.1 <c:set></c:set>

        (1) <c:set></c:set> 标签可以向域中保存数据,等价于——域对象.setAttribute(key,value);

        (2)   scope 属性设置保存到哪个域
                page 表示 PageContext 域(默认值)
                request 表示 Request
                session 表示 Session
                application 表示 ServletContext
        (3) var 属性用于设置 key(键)
        (4) value 属性用于设置 value(值)

            2.2 <c:if></c:if>

        (1) <c:if></c:if>标签用来做 if 判断。
        (2) 其中的test 属性表示判断的条件 (用 EL 表达式输出)

            2.3 <c:choose> <c:when> <c:otherwise>

        (1) 使用格式如下——

< c :choose >
        < c :when test =" ${ requestScope .score   >=  90  } " >
                <h1>牛逼~</h1>
        </ c :when >
        < c :when test =" ${ requestScope . score  >= 80   } " >
                <h1>还不错~</h1>
        </ c :when >
        < c :otherwise >
                <h1>飞舞!</h1>
        </ c :otherwise >
</ c :choose >
        (2) 如果使用EL表达式取数据时,没有指定域范围,默认是从小到大找。

            2.4 <c : forEach>/c:forEach>

        (1) <c:forEach></c:forEach>标签用来 遍历输出, 主要有以下四种遍历形式——
                ● 普通遍历输出 i 到 j (前闭后闭)
                ● 遍历数组
                ● 遍历 Map
                ● 遍历 List
        (2) 相关属性——
                1> 普通遍历 :
                        begin 属性设置开始的索引
                        end 属性设置结束的索引
                        step 属性表示遍历的步长值
                        var 属性表示循环的变量(也是当前正在遍历到的数据)
                2> 遍历数组 : 

                        items 遍历的集合
                        var 遍历到的数据 (类似于增强for;输出时会自动锁定所在域

                        eg : 
                        <%
                                request.setAttribute("books", new String[]{"哈利波特", "指环王"});
                        %>
                        <c:forEach items ="${requestScope.books}" var ="book">
                                bookName = ${book} <br/>
                        </c:forEach>
                3> 遍历Map集合 :
                        eg : 
                        <%
                                Map<String, String> students = new HashMap<>();
                                map.put("Cyan", "425");
                                map.put("Rain", "400");
                                map.put("Ice", "430");
                                request.setAttribute("students", students);
                        %>
                        <c:forEach items="${requestScope.students}" var="student">
                                Student's Info = ${student.key} --- ${student.value} <br/>
                        </c:forEach>
                4> 遍历List集合 : 
                        Δ遍历List集合与遍历Map集合时的步骤类似,都像Java 中的增强for循环结构。
                        varStatus 属性表示当前遍历到的数据的状态,可以得到 step,begin,end 等属性值
                        PS : 需要对应的JavaBean类提供相应的getXxx方法

        System.out.println("END----------------------------------------------------------------------------------------------------------------------");

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: javaweb eljstl登录页面是一种使用Java Web技术开发的登录页面。EL(Expression Language)是一种表达式语言,可以在JSP页面中使用,用于访问JavaBean中的属性和方法。JSTL(JavaServer Pages Standard Tag Library)是一组标签库,可以在JSP页面中使用,用于简化JSP页面的开发。 在javaweb eljstl登录页面中,可以使用EL表达式访问用户输入的用户名和密码,并将其传递给后台Java程序进行验证。同时,可以使用JSTL标签库来简化页面的开发,例如使用<c:if>标签来判断用户输入的用户名和密码是否为空,使用<c:forEach>标签来遍历错误信息等。 总之,javaweb eljstl登录页面是一种高效、简洁、易于维护的登录页面开发方式,可以提高开发效率和用户体验。 ### 回答2: JavaWeb是一种基于Java语言的Web应用技术,它能够利用Java语言的优秀特性构建高效可靠的Web应用程序。在JavaWeb应用程序中,EL(Expression Language)和JSTL(JavaServer Pages Standard Tag Library)是常用的组件,可以用于实现许多基础功能,如登录页面。 在JavaWeb应用中,登录页面是用户与应用程序进行交互的入口,它常具有以下几个关键要素:登录表单、用户验证、session管理以及跳转逻辑。 在使用ELJSTL实现登录页面时,首先需要创建一个登录表单,该表单应包含用户输入的用户名和密码,并过表单提交将其传递给后端进行认证。 接下来,我们可以使用EL表达式和JSTL标签库实现用户验证。EL表达式可以用来获取表单中输入的用户名和密码,并传递给Java后台进行验证。JSTL标签库也可以用来进行逻辑控制,如if语句判断验证结果是否正确。在用户过验证后,我们可以在session中存储用户信息以便后续页面使用。 最后,我们可以利用EL表达式和JSTL标签库完成跳转逻辑。可以使用JSTL中的<c:choose>和<c:when>标签来判断用户角色,并根据角色不同跳转到相应的页面。可以利用EL表达式来获取session中保存的用户信息,以便进行跳转。 总之,ELJSTLJavaWeb应用开发中常见的技术组件,能够帮助我们完成许多基础功能,如登录页面。过灵活运用这些技术组件,我们可以快构建高效可靠的Web应用程序。 ### 回答3: JavaWeb ELJSTLJavaWeb中比较常用的两个技术,它们可以帮助我们在开发中更加快捷地完成一些常见的操作。在登录页面中,我们可以运用这两个技术实现输入验证、错误提示等功能。 首先,我们可以在登录页面中使用EL表达式获取用户输入的值。EL表达式可以使用${ }的形式获取表单中的值,比如${param.username}可以获取名为username的表单项的值。我们可以将用户输入的用户名和密码保存在request中,以备后续使用。 接着,我们可以使用JSTL标签库来进行表单验证和错误提示。在表单提交之前,我们可以使用<c:if>标签对用户名和密码进行判断,看是否为空。如果有为空的情况,则可以使用<c:out>标签和错误提示来告诉用户应该输入什么信息。此外,我们还可以使用<c:choose>和<c:when>标签来进行更复杂的条件判断,以实现更加灵活的验证。 最后,我们要记得在处理登录的后台逻辑时,也要使用EL表达式和JSTL标签库来实现更加高效的操作。过这些技术的运用,我们可以快完成一个功能齐全、操作简便的登录页面,并减少代码量和维护成本。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cyan_RA9

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值