概述
- EL & jstlsh是初学当中比较难的小瓶颈
- EL只负责简化取值,jstl只负责对EL的值进行逻辑处理(jstl没有从域中取数据的能力)
- 如果要创建数据,需要在jsp脚本中执行,并把数据存放到域对象中(实际开发中,数据都是servlet获得后存储在Request域中传过来的)
- jsp有9大隐藏对象,对象是基于Servlet的.EL有11个内置对象,和jsp的对象有区别
EL表达式
EL(Express Lanuage) 表达式概述
- EL表达式可以嵌入在jsp页面内部,减少jsp脚本的编写(减少java代码)
- EL出现的目的是要替代jsp页面中脚本的编写
EL作用一:El从域中取出数据(EL最重要的作用)
- jsp脚本:<%=request.getAttribute(name)%>
- EL表达式替代上面的脚本:${requestScope.name}
- EL最主要的作用是获得四大域中的数据,格式${EL表达式}
- EL获得pageContext域中的值:${pageScope.key};
- EL获得request域中的值:${requestScope.key};
- EL获得session域中的值:${sessionScope.key};
- EL获得application域中的值:${applicationScope.key};
- EL从四个域中获得某个值${key};
- 底层用的是pageContext的findAttribute
- 同样是依次从pageContext域,request域,session域,application域中获取属性,在某个域中获取后将不在向后寻找
EL作用二:el的内置对象(11个)
- 笔试和面试也不会问这11个对象,工作中也用得少
- 只是偶尔会用到一个半个
- 内置对象是解决jsp接受数据的问题(当时大家都基本使用jsp,不用servlet,于是为了减少代码,产生内置对象,现在接受数据又由servlet来接收,很少用内置对象接收数据了)
- 现在jsp只用来展示数据,不获取数据
- EL表达式放在字符串内部没有问题,一样可以执行
pageScope,requestScope,sessionScope,applicationScope-->获取JSP中域中的数据
param,paramValues-->接收参数.相当于request.getParameter()和request.getParameterValues()
header,headerValues-->获取请求头信息.相当于request.getHeader(name)
initParam-->获取全局初始化参数.相当于this.getServletContext().getInitParameter(name)
cookie--> WEB开发中cookie.相当于request.getCookies()---cookie.getName()---cookie.getValue()
pageContext-->WEB开发中的pageContext.pageContext获得其他八大对象
- ${pageContext.request.contextPath}
- 相当于<%=pageContext.getRequest().getContextPath%> 但这句代码不能实现获得WEB应用的名称
EL作用三:el执行表达式
${1+1}
${empty user}
${user==null?true:false}
jstl
JSTL概述
- JSTL(JSP Standard Tag Library),JSP标准标签库,可以嵌入在jsp页面中使用标签的形式完成业务逻辑等功能
- jstl出现的目的同el一样也是要代替jsp页面中的脚本代码
- JSTL标准标准标签库有5个子库,但随着发展,目前常使用的是他的核心库(Core)
JSTL下载与导入
<!--使用jsp的taglib指令导入核心标签库-->
<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
jstl标签
- EL只是简化从域对象取数据的代码,不能进行逻辑判断
- 关于逻辑的代码,只能通过jstl去实现
- jstl标签经常和EL配合使用
if标签
- <c:if test=””>标签
- 其中test是返回boolean的条件
<%
request.setAttribute("count", 10);
%>
<!-- jstl标签经常会和el配合使用 -->
<!-- test代表的返回boolean的表达式 -->
<c:if test="${count==9 }(这个位置不能有空格,直接接引号,不然有误)">
xxxx
</c:if>
foreach标签
- 使用方式有两种组合形式
- foreach默认取出每一项放在pageContext域中
<c:forEach begin="0" end="10" step="1" var="i">
<br/>${i }
</c:forEach>
<c:forEach items="${productList }" var="pro">
${pro.pname }
</c:forEach>
登陆后显示名称
<form action="${pageContext.request.contextPath }/el/myel.jsp" method="post">
username:<input type="text" name="usename"><br/>
<input type="submit" value="提交"><br>
</form>
![](${pageContext.request.contextPath }/img/3.jpg)
javaEE开发模式
javaEE开发中经历过的开发模式
- model1模式:没有servlet,全部都是jsp(基本没有人用了)
- jsp + javaBean
- 弊端:很难维护,又有页面代码,又有业务代码(业务变复杂了)
- model2模式:MVC
MVC和三层架构
- MVC:model + view + control
- 三层架构:web层(与客户端交互) + service层(复杂的业务处理) + dao层(于数据库进行操作)
- mvc是web开发都有的开发模式,php,.net都有
- 三层架构是javaEE特有的
- 开发实践时三层架构通过包结构体现
- mvc是三层架构中的web层
开发中难的不是技术难,而是业务难