板块二 JSP和JSTL:第四节 EL表达式 来自【汤米尼克的JAVAEE全套教程专栏】

本文主要是介绍板块二 JSP和JSTL:第四节 EL表达式 来自【汤米尼克的JAVAEE全套教程专栏】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

板块二 JSP和JSTL:第四节 EL表达式

  • 一、什么是表达式语言
  • 二、表达式取值
      • (1)访问JSP四大作用域
      • (2)访问List和Map
      • (3)访问JavaBean
  • 三、 EL的各种运算符
      • (1).和[ ]运算符
      • (2)算数运算符
      • (3)比较运算符
      • (4)逻辑运算符
      • (5)条件运算符和empty运算符

在上一节中,我们学习了JSP的四大域对象,可是既然这四个域对象在Servlet中可以起到一模一样的作用,为什么我们还要在JSP里书写冗长的代码呢?其实JSP还有秘密武器:表达式语言(Expression Language)简称EL,它可以大幅度的减少JSP里的Java代码,这样来操作域对象就会变得格外优雅

一、什么是表达式语言

EL原本是JSTL 1.0为方便存储数据所自定义的语言,如今以及成了JSP标准的一部分,是一项成熟、标准的技术
由于JSP在整个Web程序中处于表示层,主要用于显示页面内容,在开发领域页面的设计会由专业的前端工作者完成,通常这些设计人员对Java编程不甚了解,所用的工具是HTML,因此在JSP中嵌入大量的Java源代码不利于开发的效率。为了解决这个问题,JSTL标记库应运而生,而EL就是JSTL的基础
EL的语法结构非常简单,举个栗子,观察下面代码

User user = (User)session.getAttribute("user");
String sex = user.getSex();
out.print(sex);

其作用就是从Session中得到User对象,然后在网页上印user中的sex属性
如果使用EL,要实现同样的逻辑进行表达就会变成这样

${sessiomScope.user.sex}

它的意思是,从Session作用域中取得user对象的sex属性,然后在网页上打印出来,怎么样,是不是非常简便?
其实EL的基本语法结构就是

${expression}

有几点重要注意事项:

  • EL表达式一般操作的都是域对象中的数据操作不了局部变量
  • 还记得上一节总结的四大鱼对象吗?EL表达式在取域对象中的数据时,范围是page->request->session->application从小到大取的,一旦有同名变量就取走了
  • 如果EL表达式获取对象的值为,默认显示空字符串

二、表达式取值

(1)访问JSP四大作用域

EL表达式取四个作用域里的值有对应的名称

作用域名称
PagepageScope
RequestrequestScope
SessionsessionScope
ApplicationapplicationScope

实例,在hello.jsp中写入测试代码,分别在Session和Application作用域中存取数据

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html><body><%session.setAttribute("sessMsg","这里是session作用域");application.setAttribute("appMsg","这里是application作用域");%>${sessionScope.sessMsg} <br>${applicationScope.appMsg}</body>
</html>

启动服务器,在浏览器中访问hello.jsp,可得
在这里插入图片描述

(2)访问List和Map

在表达式中可以用${list[num]}来直接访问List中的某位元素(list是数组的自定义名字)
实例,在hello.jsp中写入

<%@ page import="java.util.List" %>
<%@ page import="java.util.ArrayList" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html><body><%// ListList<String> list =new ArrayList<>();list.add("aaa");list.add("bbb");list.add("ccc");request.setAttribute("list", list);%>// list是数组的名字获取List的size:${list.size()}<br>获取List的指定下标的值:${list[1]}<br></body>
</html>

启动服务器,在浏览器中访问hello.jsp可得
在这里插入图片描述


同样可以用${map.}${map[]}来直接访问Map中的某对键值对(map是数组的自定义名字)
实例,在hello.jsp中写入

<%@ page import="java.util.HashMap" %>
<%@ page import="java.util.Map" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html><body><%// MapMap map =new HashMap();map.put("aaa","111");map.put("bbb",222);map.put("ccc",33);request.setAttribute("map",map);%>获取Map的某对键值对:${map.aaa} <br>获取Map的某对键值对:${map["bbb"]}</body>
</html>

启动服务器,在浏览器中访问hello.jsp可得
在这里插入图片描述

在代码中我们发现实际上List和Map是存在Request作用域中的,但在用表达式取值时居然没有写requestScope.前缀也能拿到,其实此时表达式访问List和Map是在四个作用域中由从小到大的范围寻找的,所以也可以省略作用域前缀,如果加上前缀就是只在指定作用域中寻找

(3)访问JavaBean

JavaBean一般由Servlet实例化,由JSP显示其中的内容
什么?你问我什么是JavaBean?举个栗子,你肯定见过,简单来说就是一个public修饰的Java类里面定义了几个private属性,并且提供了属性相应的get/set方法(如果boolean 则get可以替换成is),它就是JavaBean
实例
com.caijiyuan包下新建一个User类,写入两个属性,并且alt+ins生成两个属性的get/set方法
在这里插入图片描述
再添上一个User类的带参构造函数,总体代码如下

package www.caijiyuan;public class User {private Integer userId;private String uname;public User(Integer userId, String uname) {this.userId = userId;this.uname = uname;}public Integer getUserId() {return userId;}public void setUserId(Integer userId) {this.userId = userId;}public String getUname() {return uname;}public void setUname(String uname) {this.uname = uname;}
}

在hello.jsp中new一个user实例并且传参,别忘了把实例放在Request作用域里

<%@ page import="www.caijiyuan.User" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html><body><%// UserUser user = new User(1959,"Toomynike");request.setAttribute("user",user);%>获取User的名字:${user.uname} <br>获取UserID:${user.userId}</body>
</html>

启动服务器,在浏览器中访问hello.jsp可得
在这里插入图片描述

三、 EL的各种运算符

(1).和[ ]运算符

EL 提供.[]两种运算符来存取数据。当要存取的属性名称中包含一些特殊字符,就只能使用 [],例如这样书写是错误的

${user.My-Name}

必须写成

${user["My-Name"] }

如果要动态取值时,也必须用[]来做,.无法做到动态取值,例如data是一个变量时

${sessionScope.user[data]}

(2)算数运算符

它们也是直接写在${}中,会直接将运算结果打印出来

算数运算符说明实例打印的结果
+${10+2}12
-${10-2}8
*${10*2}20
/div${10/4}${10div2}2.5
%mod取模${10%4}${10mod2}2

(3)比较运算符

比较运算符返回bool类型

算数运算符说明实例打印的结果
==eq等于${10==2}${10 eq 2}false
!=ne不等于${10!=2}${10 ne 2}true
<lt小于${10<2}${10 lt 2}false
>gt大于${10>2}${10 gt 2}true
<=le小于等于${10<=2}${10 le 2}false
>=ge大于等于${10 >=2}${10 ge 2}true

(4)逻辑运算符

逻辑运算符也是返回bool类型

算数运算符说明实例打印的结果
&&and逻辑与${true && false}或者{ture and false}false
丨丨or逻辑或${fasle 丨丨 true}或者{false or true}true
!not逻辑非${!true}${not ture}false

(5)条件运算符和empty运算符

  • 条件运算符
    A为真则返回B,否则返回C
${A?B:C}
  • empty运算符

A为null\空字符串\空数组返回true,否则返回false

${empty A}

以上就是此小节的全部内容,学会了EL让我们的JSP格外优雅,下一节开始我们将学习JSTL,让JSP既优雅又强大

这篇关于板块二 JSP和JSTL:第四节 EL表达式 来自【汤米尼克的JAVAEE全套教程专栏】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/743582

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�