JSP脚本带来的问题
不知道看到这几个子,各位有什么想法?反正我觉得JSP就像孙猴子法力无边但是不服管教,是令人头疼的东西。为什么呢?JSP脚本极大的提高了程序的复杂性,同时JSP脚本也增加了代码阅读的困难。最后,也是最令人头疼的问题就是调试麻烦(感受深刻)。这就是源头了,你要是觉得体会不够深刻的话可以自己动手试试写JSP脚本从JSP1.1开始,JSP就支持在JSP中使用自定义标签,来解决JSP脚本所带来的问题。但是,自定义标签的广泛使用引发了新的问题,即重复定义、复用性差。因此,SUN公司推出了标签的标准,即JSTL(JSP Standard Tag Libaray),而Apach实现了JSTL规范。下面价绍JSTL……
JSTL 简介
JSTL包括五类标准标记库:核心库、格式库、XML库、SQL库、函数库。如下图所示:JSTL实际上是以另一种良好的界面或者说接口来代替了JSP脚本的工作,大家知道JSP页面是会被解析成Servlet的所以WebServlet容器在引入JSTL后肯定是要有对应的解析器。然后,就和原来使用JSP脚本没什么区别了。也就是说JSTL所做的工作是一种优化。
另外呢,JSTL和EL表达式都是一块使用的,但是EL表达式不算是JSTL的一部分。因为,没有JSTL的情况下,EL表达式也是可以使用的。虽然有的资料直接说JSTL包括JSTL和EL表达式两个部分,应该是不太妥当的。所以,EL表达式会在下篇博客单独介绍。
实例体验
这是在使用JSP脚本和JSTL所做的循环输出。
JSP版本:<% List itemList = pageModel.getList(); for (Iterator iter = itemList.iterator(); iter.hasNext();) { Item item = (Item) iter.next(); %> <tr> <td class="rd8"> <input type="checkbox" name="selectFlag" class="checkbox1" value="<%=item.getItemNo()%>"> </td> <td class="rd8"> <a href="" onClick="window.open('item_detail.html', '详细信息', 'width=400, height=400, scrollbars=no');"><%=item.getItemNo()%></a> </td> <td class="rd8"> <%=item.getItemName()%> </td> <td class="rd8"> <%=item.getSpec()%> </td> <td class="rd8"> <%=item.getPattern()%> </td> <td class="rd8"> <%=item.getItemCategory().getName()%> </td> <td class="rd8"> <%=item.getItemUnit().getName()%> </td> </tr> <% } %>
JSTL版本:
<c:forEach items="${pageModel.list}" var="item" > <tr> <td class="rd8"> <input type="checkbox" name="selectFlag" class="checkbox1" value="${item.itemNo }"> </td> <td class="rd8"> <a href="#" onClick="window.open('item_detail.html', '物料详细信息', 'width=400, height=400, scrollbars=no');">${item.itemNo }</a> </td> <td class="rd8"> ${item.itemName } </td> <td class="rd8"> ${item.spec } </td> <td class="rd8"> ${item.pattern } </td> <td class="rd8"> ${item.itemCategory.name } </td> <td class="rd8"> ${item.itemUnit.name } </td> </tr> </c:forEach>
总结:总的来说,JSTL最大的特点就是简单。它相当于对JSP脚本做了一次封装,或者说是外观模式的应用吧。将复杂的逻辑处理隐藏起来,对外提供统一的接口。也就是说JSP页面的开发可以不依赖于Java代码了,即在现在分工越发明细,职责越发单一的开发趋势下为web开发的现实和逻辑划清了界限。也就是说在开发人员的配置上实现了解耦和。