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

JAVA学习篇--JSTL基础

时间:2014-07-08 11:16:50      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   java   使用   文件   

JSTL是什么

 

JSTL(JSP Standard TagLibrary,JSP标准标签库)是一个不断完善的开放源代码的JSP标签库。

 

为什么要用JSTL

 

我们JSP用于开发信息展现页非常方便;也可以嵌入java代码(scriptlet、表达式和声明)代码用来实现相关逻辑控制。看下面程序。但这样做会带来如下问题:

jsp维护难度增加;出错提示不明确,不容易调试; 分工不明确;(即jsp开发者是美工,也是程序员);

最终增加程序的开发成本; 


<% if (session.getAttribute(“user”).equals(“member”)) { %>  
<p>Welcome, member!</p>  
<% } else { %>  
<p>Welcome, guest!</p>  

<% } %>

由来:

 

JSTL的初衷是为了将前台美工同开发分开,很好的实现分层开发的目标。我们知道大多数的美工是对标签比较熟悉


JSTL的最大优势

 

1:让页面代码看起来更加整洁,显示逻辑一目了然,风格统一,易于维护 

2:大量使用JSTL提供的逻辑操作(例如迭代、判断),可以大大减少JSP中脚本代码(Scriptlets)的数量

3:很好的实现了分层的思想! 

4:对于美工人员来说更加容易学习和掌握,因为美工的一部分工作就是和各种标签打交道 

5:而且同样可以对其进行自定义扩展! 


弊端:


1,为前台美工人员,维护人员增加了学习成本

 

使用简介:

 

如果要使用JSTL,则必须引用jstl.jar和standard.jar两个包。

并在jsp文件的顶部加入以下内容:


<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>   
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>  
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %> 

主要标签分类:

 

<c:> 核心标签库

包括与表达式相关的标签,输出JSP页面内容时的流程制标签,迭代操作标签,生成和操作URL的标签.

JSTL核心标签库(C标签)标签共有13个,功能上分为4类:

1.表达式控制标签:out、set、remove、catch

2.流程控制标签:if、choose、when、otherwise

3.循环标签:forEach、forTokens

4.URL操作标签:import、url、redirect

 

<fmt:>   格式化标签库

定义了用来格式化数据(尤其是数字和日期)的操作还支持使用本地化资源束进行JSP页面的国际化


<fn:> Function标签库

提供了一组常用的 EL函数,主要用于处理字符串,在 JSP 中可以直接使用这些函数

 


JSTL一般配合EL一起使用,因此先看看EL.


EL(Expression Language)目的:为了使JSP写起来更加简单


语法结构:${expression}

举例:< %=request.getParameter(“username”)% > 等价于 ${ param. username }


下面我们来应用JSTL来修改一下jsp的页面:

 

使用JSTL之前:


<td>
		<select name="category" class="select1" id="category">
			<%
				for (int i=0; i<itemCategoryList.size(); i++) {
					ItemCategory ic = (ItemCategory)itemCategoryList.get(i);
					String selectedString = "";
					if (item.getItemCategory().getId().equals(ic.getId())) {
						selectedString = "selected";
					}
			%>
				<option value="<%=ic.getId() %>" <%=selectedString %>><%=ic.getName() %></option>
			<%
				}
			%>
		</select>
</td>


使用JSTL之后:


<td>
		<select name="category" class="select1" id="category">
			<!-- 遍历list数组,将值存放到itemCategory中 -->
			<c:forEach items="${itemCategoryList}" var="itemCategory">
				<c:set var="selectedString"/>
				<!-- 如果item.itemCategory.id等于itemCategory.id -->
				<c:if test="${item.itemCategory.id eq itemCategory.id}">
					<!-- 将selected的值存放到selectedString变量中 -->
					<c:set value="selected" var="selectedString"/>
				</c:if>
				<option value="${itemCategory.id }" ${selectedString }>${itemCategory.name }</option>
			
			</c:forEach>
			
	</select>

</td>

总结:


对于JSTL来说,它对jsp页面进行了进一步的拆分,将jsp页面中的JAVA代码,隔离出来,不必要美工去关心java代码的实现,只考虑界面的美化即可,这样职责单一,分工明确。

在做DRP项目总结时,深刻体会到,其实我们现在学的好多技术实际都是抽象的不断扩展和延伸,是为了程序的复用性和易用性增加!我们都是在不断抽象,不断总结,不断简单化地进行学习!让我们的程序更加面向变化!




JAVA学习篇--JSTL基础,布布扣,bubuko.com

JAVA学习篇--JSTL基础

标签:style   blog   http   java   使用   文件   

原文地址:http://blog.csdn.net/hejingyuan6/article/details/36695913

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