动态页面技术(EL/JSTL)
EL技术
EL 表达式概述
EL(Express Lanuage)表达式可以嵌入在jsp页面内部,减少jsp脚本的编写,EL出现的目的是要替代jsp页面中脚本(java代码)的编写。
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域,request域,session域,application域中获取属性,在某个域中获取后将不在向后寻找
1)获得普通字符串
2)获得User对象的值
3)获得List<User>的值
<!-- 模拟域中的数据 --> <% pageContext.setAttribute("name", "pageContxt"); //存储字符串 request.setAttribute("name", "request"); //存储一个对象 Users user=new Users(); user.setId(1); user.setUsername("lisi"); user.setPwd("123"); session.setAttribute("user", user); //存储一个集合 List<Users> list=new ArrayList<Users>(); Users user1=new Users(); user1.setId(1); user1.setUsername("wangwu"); user1.setPwd("123"); list.add(user1); Users user2=new Users(); user2.setId(1); user2.setUsername("zhaoliu"); user2.setPwd("123"); list.add(user2); application.setAttribute("List", list); %> <hr> <!-- 使用脚本取出域中的值 --> <%=request.getAttribute("name") %> <%Users u=(Users)session.getAttribute("user"); out.write(u.getUsername()); %> <hr> <!-- 使用EL表达式取出域中的值 --> ${requestScope.name} ${sessionScope.user.username} ${applicationScope.List[0].pwd} <hr> <!-- 使用el表达式 全域查找(会从最小的找,底层就是findAttribute()) --> ${name } ${user.username} ${List[0].pwd}
EL的内置对象11个
①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()
Form.html <form action="/WEB02/form.jsp" method="get"> <input type="text" name="username"> <input type="text" name="password"> <input type="submit" value="提交"> </form>
Form.jsp <!-- 获得表单的参数 --> <% request.getParameter("username"); //..... %> <!-- 使用EL获得参数 --> ${param.username } ${header["User-Agent"] } ${cookie.abc.value } <!-- 通过el表达式获得request对象 --> <%--${requestScope } --%> ${pageContext.request }
Cookie.jsp <% Cookie cookie=new Cookie("abc","zhangsan"); response.addCookie(cookie); %>
Index.jsp <form action="${pageContext.request.contextPath }/form.jsp" method="get"> <input type="text" name="username"> <input type="text" name="password"> <input type="submit" value="提交"> </form>
pageContext - WEB开发中的pageContext.
pageContext获得其他八大对象
${pageContext.request.contextPath}
EL执行表达式
例如:
${1+1}
${empty user}
${user==null?true:false}
JSTL技术
JSTL概述
JSTL(JSP Standard Tag Library),JSP标准标签库,可以嵌入在jsp页面中使用标签的形式完成业务逻辑等功能。
jstl出现的目的同el一样也是要代替jsp页面中的脚本代码。JSTL标准标准标签库有5个子库,但随着发展,目前常使用的是他的核心库
JSTL下载与导入
JSTL下载:
从Apache的网站下载JSTL的JAR包。进入“http://archive.apache.org/dist/jakarta/taglibs/standard/binaries/”网址下载 JSTL的安装包。
jakarta-taglibs-standard-1.1.2.zip,然后将下载好的JSTL安装包 进行解压,此时,在lib目录下可以看到两个JAR文件,分别为jstl.jar和standard.jar。
其中,jstl.jar文件包含JSTL规范中定义的接口和相关类,standard.jar文件包含用于 实现JSTL的.class文件以及JSTL中5个标签库描述符文件(TLD)
将两个jar包导入我们工程的lib中
使用jsp的taglib指令导入核心标签库
JSTL核心库的常用标签
1)<c:if test=””>标签
其中test是返回boolean的条件
<%request.setAttribute("count", 10); %> <!--jstl标签经常会和el配合使用 --> <!-- test代表的返回boolean的表达式 --> <c:if test="${count==10 }"> xxxx </c:if>
Index.jsp <!-- 用户没有登陆 --> <c:if test="${empty user }"> <a href="login.jsp">登陆</a> <a href="register.jsp">注册</a> </c:if> <!-- 用户已经登陆 --> <c:if test="${!empty user }"> <span>${user.name }</span> <a href="#">退出</a> </c:if>
Ceshi.jsp <% //模拟用户已经登录成功 User user=new User(); user.setId(100); user.setName("张三"); user.setPwd("123"); session.setAttribute("user", user); %>
2)<c:forEach>标签
使用方式有两种组合形式:
<!-- 模拟增强for productList---List<Product> for(Product product:productList){ System.out.print(product.getName()); } -->
<!-- items:一个集合或数组(从域中选) var:代表集合中的某一个元素 --> <c:forEach items="${productList }" var="pro"> ${pro.name } </c:forEach> <c:forEach items = "${map}" var="entry">
${entry.key }->${entry.value.name }<br>
</c:forEach>
事例:
<!-- 取集合list中的值 -->
<c:forEach items="${userlist}" var="user">
${user.name }...${user.age }<br>
</c:forEach>
<!-- 取集合map中的值 -->
<c:forEach items="${usermap }" var="entry">
${entry.key }...${entry.value }<br>
</c:forEach>
<!-- 嵌套取值 -->
<c:forEach items="${usermap}" var="entry">
${entry.key}...${entry.value}<br>
<c:forEach items="${entry.value}" var="entry1">
${entry1.key}...${entry1.value}<br>
</c:forEach>
</c:forEach>
<!-- 打印三角形 -->
<c:forEach begin="0" end="4" var="i">
<c:forEach begin="0" end="${i }" var="j">
<%System.out.print("*");%>
</c:forEach>
<%System.out.println();%>
</c:forEach>
动态页面技术(EL/JSTL)的更多相关文章
- 动态页面技术----EL技术、JSTL技术,javaEE的开发模式
1 EL技术 1.1 EL 表达式 EL(Express Lanuage)表达式可以嵌入在jsp页面内部,减少jsp脚本的编写, EL出现的目的是要替代jsp页面中脚本的编写,就是简化java代码. ...
- 动态页面技术EL
1.EL概述: EL表达式可以嵌入再JSP页面内部,减少JSP脚本的编写 EL出现的目的是要替代JSP页面中脚本的编写 EL最重要的作用就是从域中取出数据: 引入: JSP中<%=request ...
- 动态页面技术JSP/EL/JSTL
本节内容: jsp脚本和注释 jsp运行原理 jsp指令(3个) jsp内置/隐式对象(9个) jsp标签(动作) EL技术 JSTL技术 JavaEE的开发模式 动态页面技术:就是在html中嵌入j ...
- JavaEE之动态页面技术(JSP/EL/JSTL)
动态页面技术(JSP/EL/JSTL) JSP技术 jsp脚本和注释 jsp脚本: 1)<%java代码%> ----- 内部的java代码翻译到service方法的内部 2)<%= ...
- java ->动态页面技术(JSP)
动态页面技术(JSP/EL/JSTL) JSP技术 jsp脚本和注释 jsp脚本: 1)<%java代码%> ----- 内部的java代码翻译到service方法的内部 2)<%= ...
- JavaWeb之动态页面技术JSP/EL/JSTL
一.JSP技术 1.jsp脚本和注释 jsp脚本: 1)<%java代码%> ----- 内部的java代码翻译到service方法的内部 2)<%=java变量或表达式> - ...
- Java第三阶段学习(十四、JSP动态页面、EL表达式、JSTL标签库)
一.JSP技术 1.jsp脚本和注释 jap脚本: 1)<%java代码%> ----- 内部的java代码翻译到service方法的内部,比如写在doget.dopost 内的代码 2) ...
- 动态页面技术----JSP技术
1995年java诞生,没有jsp,只有Servlet, Servlet开发:Servlet上嵌套html代码,非常繁琐. 1998年,出现jsp,方便写html代码,并且可以在html代码中嵌套ja ...
- 动态页面技术(JSP)
JSP技术 jsp脚本和注释 jsp脚本: 1)<%java代码%> ----- 内部的java代码翻译到service方法的内部 2)<%=java变量或表达式> ----- ...
随机推荐
- 小师妹学JVM之:JIT中的PrintAssembly
目录 简介 使用PrintAssembly 输出过滤 总结 简介 想不想了解JVM最最底层的运行机制?想不想从本质上理解java代码的执行过程?想不想对你的代码进行进一步的优化和性能提升? 如果你的回 ...
- python之浅谈循环
目录 流程控制之while循环 语法 while+break while+continue while+else while循环的嵌套 流程控制之for循环 语法 for+break for+cont ...
- 新技术新框架不断涌现,目前学习web前端开发都要掌握什么?
web前端开发由网页制作演变而来,随着web2.0的发展,网页不再只是承载单一的文字和图片,各种丰富媒体让网页的内容更加生动,网页上软件化的交互形式为用户提供了更好的使用体验,这些都是基于前端技术实现 ...
- redis.cluster/memcached.cluster/wmware esxi
1. 安装配置redis的cluster 集群 redis 集群高可用 实验环境 192.168.198.131 openvpn-server #42-Ubuntu SMP Mon Jun 8 14: ...
- 理解css中Grid布局,在项目中如何实现grid页面布局
简介 CSS中Grid是一种二维网格式布局方式.我们常规使用table.float.position.inline-block等布局,但它们遗漏了很多功能,例如垂直居中.后来css3中flexbox的 ...
- css完美解决网页在iphoneX的头部刘海显示问题
一.解决iphonX白条,网站扩展到整个屏幕 网页在iphoneX的浏览器屏幕显示上,默认情况下在头部的2侧会出现白条背景,网站被限制在了一个“安全区域”内,移除白色背景的方法 方法一:设置body的 ...
- APP开发---后台设计
想了好久才准备写博客的,希望能对我自己和大家都有帮助! 话不多说,直接正题! ------------------------------------------------------------- ...
- Aspose下载图片
/// <summary> /// 把DataTable数据按照Excel模板导出到Excel /// </summary> /// <param name=" ...
- python 读取指定文件夹中的指定文件类型的文件名
import numpy as np import os path = 'F:\\wenjian'#指定文件所在路径 filetype ='.csv'#指定文件类型 def get_filename( ...
- Resource exhausted: OOM when allocating tensor with shape[3,3,384,384] and type float on /job:localhost/replica:0/task:0/device:GPU:0 by allocator GPU_0。。。。。
报错信息: OP_REQUIRES failed at assign_op.h:111 : Resource exhausted: OOM when allocating tensor with sh ...