码迷,mamicode.com
首页 > 编程语言 > 详细

java基础开发—jstl标签库

时间:2014-09-30 22:06:40      阅读:251      评论:0      收藏:0      [点我收藏+]

标签:style   http   color   io   os   使用   ar   java   strong   

   在DRP项目中,接触到了JSTL标签库。在未使用Jstl之前,我们使用JSP脚本实现一些声明或是表达式任务,做一些业务相关操作时,需要在页面中嵌入大量的java代码。在DRP项目开发前期,使用jsp页面给我的感受就是,jsp页面什么活都能干,权利过高。导致的结果就是,jsp页面提高了程序的复杂性、增强了代码维护的复杂度,以及代码阅读的困难,对程序员的要求也相对较高,例如,尽管精通页面设计的开发人员来维护jsp,也常常需要依赖于经验丰富的程序员。所以需要一种技术来解决这些问题,下面简单介绍一下jstl: 


   Jstl(JSP Standard Tag Library)是由SUN公司提出的JSP的一个标准标签库。将常用功能包装到定制标记库集合中。这些标记库跟HTML标签不同,它主要应用与服务器端。

  JSTL包括五类标准标记库:核心库、格式库、XML库、SQL库、函数库。同时Jstl是与EL表达式一同使用的,E L(Expression Language) 目的:为了使JSP写起来更加简单。个人认为其并不属于jstl,而是jstl使用了el表达式,一起更方便的服务于jsp。  


EL表达式 

语法:$和{} 

内置对象: pageScope,requestScope,sessionScope,applicationScope 

  Empty操作符:决定对象、集合或字符串变量是否为空或null,例如:

       servlet中定义:request.setAttribute("v2", "");

jsp:v1:${empty v1}<br>

“.“和“[ ]“两种运算符来存取数据:例如:

${user.username}    

        ${users[5].username }

      运算符:【==/eq   !=/ne   </lt     >/gt    &&/and    ||/or   !/not    //div    %/mod】 例如:

<li>el表达式对运算符的支持</li><br>
	1+1=${1+1 }<br>
	10/5=${10/5 }<br>
	10 div 5=${10 div 5 }<br>
	10 % 3=${10 % 3 }<br>
	10 mod 3 = ${ 10 mod 3 }<br>

Jstl标签库:

   在使用jstl前提需要引入jstl.jarstandard.jar两个jar包。


1.核心库:引入<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="c"%>   

c:out标签:hello(使用标签):<c:out value="${hello}"/><br>

c:set标签:<c:set value="root" var="userid"/>

c:remove标签:<c:remove var="userid"/>

        条件控制标签:c:if、c:choose、c:when

<c:choose>
		<c:when test="${v1 gt v2}">
			v1大于v2<br>
		</c:when>
		<c:otherwise>
			v1小于v2<br>
		</c:otherwise>
	</c:choose>
	<c:choose>
		<c:when test="${empty userList}">
			没有符合条件的数据<br>
		</c:when>
		<c:otherwise>
			存在用户数据<br>
		</c:otherwise>
	</c:choose>

 循环控制标签

<c:choose>
			<c:when test="${empty users}">
				<tr>
					<td colspan="3">没有符合条件的数据</td>
				</tr>
			</c:when>
			<c:otherwise>
				<c:forEach items="${users}" var="user">
					<tr>
						<td>${user.username }</td>
						<td>${user.age }</td>
						<td>${user.group.name }</td>
					</tr>
				</c:forEach>
			</c:otherwise>
		</c:choose>


2.函数库:引入<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%>   

<body>	
	hello.length(使用JSTL的length函数, 函数必须放到EL表达式中,用法:前缀+冒号+函数名称):${fn:length(hello) }<br>
	<p>
	<c:forEach items="${fn:split(str, \"#\") }" var="v">
		${v }<br>
	</c:forEach>
	<p>
	自定义函数:${my:say("张三") }<br>
</body>


3.格式化库:引入<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fm"%>   

下面是获取时间和日期的三种形式

today(type="date"):<fmt:formatDate value="${today}" type="date"/><br>
	today(type="time"):<fmt:formatDate value="${today}" type="time"/><br>
	today(type="both"):<fmt:formatDate value="${today}" type="both"/><br>


DRP项目中遍历下拉框实例:

1.未使用Jstl 

<tr>
						<td height="26">
							<div align="right">
								<font color="#FF0000">*</font>类别: 
							</div>
						</td>
						<td>
						<%
							List<ItemCategory> itemCategoryList = (List)request.getAttribute("itemCategoryList");
						%>							
							<select name="category" class="select1" id="category">
							<%
								for(Iterator<ItemCategory> iter = itemCategoryList.iterator();iter.hasNext();){
									ItemCategory ic = iter.next();
							%>								
									<option value="<%=ic.getId()%>"><%=ic.getName()%></option>
								<%
									}
								%>
							</select>
						</td>
					</tr>

2.使用jstl

<tr>
						<td height="26">
							<div align="right">
								<font color="#FF0000">*</font>类别: 
							</div>
						</td>
						<td>											
							<select name="category" class="select1" id="category">
								<c:forEach items="${itemCategoryList }" var="itemCategory">
									<option value="${itemCategory.id }">${itemCategory.name }</option>
								</c:forEach>
							</select>
						</td>
					</tr>


总结:

   对于程序员来说,不将就是发现问题的动力源泉,有什么样的需求,就会创造出什么样的技术和工具。Jstl封装了web应用程序的一些通用功能,我们在使用的时候,不必需要理解其内部是如何实现的,只需要了解其标签每个标签代表的功能即可。jstl的出现削弱jsp页面过高的权利,使jsp页面分层更加清楚而出现的。


java基础开发—jstl标签库

标签:style   http   color   io   os   使用   ar   java   strong   

原文地址:http://blog.csdn.net/mingxuanyun/article/details/39698161

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!