4. <bean:message>
标签处理资源配置文件被
<fmt:bundle>
、
<fmt:setBundle>
、
<fmt:message>
标签合作替换
q
原形:
<bean:message>
标签是专门用来处理资源配置文件显示的,而它的资源配置文件被配置在
struts-config.xml
的
<message-resources>
元素中。
q
替换方案:利用
<fmt:bundle>
、
<fmt:setBundle>
、
<fmt:message>
标签合作来替换,由
<fmt:bundle>
、
<fmt:setBundle>
设置资源配置文件的实体名称,再由
<fmt:message>
标签负责读取显示。
<bean:message>
标签的动作:
<bean:message key="message.attacksolution"/>
<fmt:bundle>
、
<fmt:message>
标签的动作:
<fmt:bundle basename="resources.application">
<fmt:message key="message.attacksolution" />
</fmt:bundle>
或
<fmt:setBundle>
、
<fmt:message>
标签的动作:
<fmt:setBundle basename="resources.application" var="resourceaApplication"/>
<fmt:message key="message.attacksolution" bundle="${resourceaApplication}"/>
q
比较结果:这一对标签
对于国际化的支持都相当好,唯一最大的区别在于利用
<bean:message>
标签所操作的资源配置文件是配置在
struts-config.xml
中的,而
<fmt:message>
标签所操作的资源配置文件则是根据
<fmt:bundle>
、
<fmt:setBundle>
两组标签来得到的。看起来,后者的灵活性不错,但就笔者的眼光来看,前者更为规范,对于用户协作的要求也更高。试想,维护一到两个资源配置文件与维护一大堆资源配置文件哪个更方便呢?自然是前者了,因此除非是不依赖
Struts
框架的应用,否则最好使用
<bean:message>
标签。
Struts Logic
标签库中的标签在页面显示时是时常被用到的,但是常用的却不一定是最好用的,有了
JSTL
标签库和
EL
表达式后,许多
Struts Logic
标签库的标签可以被简单替换。
1.
所有判断标签被
EL
表达式和
<c:if>
标签替换
q
原形:判断标签有一个特点,就是需要取得一个实例的变量,因此通过
<bean:define>
标签来取得实例的变量是必须的,随后就通过各种判断标签来完成判断的工作。常用的判断标签如表
9.30
所示:
表9.30 常用判断标签
标签名
|
描述
|
empty
|
判断变量是否为空
|
notEmpty
|
与empty标签正好相反
|
equal
|
判断变量是否与指定的相同
|
notEqual
|
与equal标签正好相反
|
lessThan
|
判断变量是否比指定的小
|
greaterThan
|
判断变量是否比指定的大
|
lessEqual
|
判断变量是否小于等于指定的值
|
greaterEqual
|
判断变量是否大于等于指定的值
|
present
|
检查header、request parameter、cookie、JavaBean或JavaBean propertie不存在或等于null的时候,判断成功
|
notPresent
|
与present标签正好相反
|
match
|
比较String类型字符串是否与指定的相同
|
notMatch
|
与match标签正好相反
|
q
替换方案:利用
EL
表达式和
<c:if>
标签来替换。
q
示例比较:判断标签的动作:
<bean:define id="javaBeanName"
name="javaBeanParameter"
property="attack_event_code"
scope="request"/>
<logic:notEmpty name="javaBeanParameter">
javaBeanParameter not empty
</logic:notEmpty>
EL
表达式和
<c:if>
标签的动作:
<c:if test="${requestScope.javaBeanParameter.attack_event_code != null
&& requestScope.javaBeanParameter.attack_event_code != ''”}>
javaBeanParameter not empty
</c:if>
EL
表达式利用操作符来完成判断动作,然后通过
<c:if>
标签来根据判断结果处理对应工作。
q
比较结果:
EL
表达式的操作符
对判断的贡献很大,
EL
表达式的灵活性是
Struts
判断标签无法比拟的,任何判断标签都可以通过表达式来实现。
<c:if>
标签还可以将判断的结果保存为一个变量,随时为之后的页面处理服务。
反观
Struts
框架的判断标签,在工作之前必须先定义被判断的变量,而判断后又无法保存判断结果,这样的程序设计远不如
EL
表达式和
<c:if>
标签的协作来得强大。因此使用
EL
表达式和
<c:if>
标签来替换判断标签是更好的选择。
2. <logic:iterate>
标签被
<c:forEach>
标签和
EL
表达式替换
q
原形:
<logic:iterate
>
标签用来对集合对象的迭代,可以依次从该集合中取得所需要的对象。
q
替换方案:利用
<c:forEach>
标签和
EL
表达式的协作替换
<logic:iterate
>
标签。
q
示例比较
<logic:iterate
>
标签的动作:
<logic:iterate name="allAttackSolution"
id="attackSolution"
type="struts.sample.cap1.sample3.entity.AttackSolution">
<bean:write property="attack_event_code" name="attackSolution"/>
<bean:write property="attack_mean" name="attackSolution"/>
<bean:write property="attack_action" name="attackSolution"/>
</logic:iterate>
<c:forEach>
标签
EL
表达式协作的动作:
<c:forEach items="${requestScope.allAttackSolution}" var="attackSolution">
${attackSolution.attack_event_code}
${attackSolution.attack_mean}
${attackSolution.attack_action}
</c:forEach>
两个动作都做的是同一件事,从
request
中得到保存的“
allAttackSolution
”参数,该参数为一个集合,集合中的对象为
struts.sample.cap1.sample3.entity.AttackSolution
类型的实例。
<logic:iterate
>
标签本身可以接收集合,保存为一个变量,利用迭代子模式,使
<logic:iterate
>
标签体中的
<bean:write>
标签将集合中的每个
JavaBean
显示出来。
提示:在本例中由于要显示JavaBean中的变量属性,因此<bean:write>标签还需要设置property属性。
替换工作的
<c:forEach>
标签则相对要方便些,
items
属性使用
EL
表达式取得集合,然后设置
var
属性作为集合中对象的变量,最后使用
EL
表达式来显示数据。
q
比较结果:
值得注意的一个地方是,
<logic:iterate
>
标签必须为集合中的对象指定类型,因为标签库处理时会将集合中的对象作为
Object
类型得到,然后需要读取
type
属性定义的
Java
类为它强制转型。
而
<c:forEach>
标签则完全不用,只要符合标准
JavaBean
(为变量属性提供
get
、
set
方法)的对象都可以通过
EL
表达式来从
var
属性定义的变量中取得该
JavaBean
的变量属性。
因此
<c:forEach>
标签和
EL
表达式的方式更加简单,也更加灵活。
当然,熟悉
<logic:iterate
>
标的程序设计者也可以将
<bean:write>
标签替换为
EL
表达式而仍然使用
<logic:iterate
>
标签。代码可以是这样:
<logic:iterate name="allAttackSolution"
id="attackSolution"
type="struts.sample.cap1.sample3.entity.AttackSolution">
${attackSolution.attack_event_code}
${attackSolution.attack_mean}
${attackSolution.attack_action}
</logic:iterate>
结果一样,但这种方式比
<bean:write>
标签显示方式灵活多了。
3. <logic:redirect>
标签被
<c:redirect>
和
<c:param>
标签替换
q
原形
:
<logic:redirect
>
标签用来转发到一个页面,并可以为转发传递参数。
q
替换方案:利用
<c:redirect>
和
<c:param>
标签的协作替换
<logic:redirect
>
标签。
q
示例比较:
<logic:iterate
>
标签的动作:
<%
HashMap paramMap = new HashMap();
paramMap.put("userName", "RW");
paramMap.put("passWord", "123456");
%>
<logic:redirect page="/MyHtml.jsp" name="paramMap" scope="request" />
<c:redirect>
和
<c:param>
标签协作的动作:
<c:redirect url="/MyHtml.jsp">
<c:param name="userName" value="RW"/>
<c:param name="passWord" value="123456"/>
</c:redirect>
两个动作都做的是同一件事,都将转发到当前
Web Context
下的“
MyHtml.jsp
”去,而且都将为它提供两个参数。最后的转发链接看起来应该如下所示:
http://localhost:8080/test/ MyHtml.jsp? userName=RW&password=123456
q
比较结果
一眼就可以看出,
<logic:redirect
>
标签的可读性
不强,它的
name
属性表示的是一个
Map
类型的变量。如果还有
property
属性,则
name
属性指的是一个标准
JavaBean
。
property
属性指的是
JavaBean
中的一个
Map
类型的变量属性,通过
Map
的“名值对”来为转发页面传递参数。如果转发参数是来自于一个
Map
或
JavaBean
中的
Map
类型变量属性,那还好,因为可以在
Java
类中处理。可是如果纯粹是从页面上取得某些值作为转发参数,那就困难了,必须像本示例
所给出的那样,自行定义一个
Map
实例
。这种情况下,页面就会看到
Java
语言的片段,既麻烦又不符合标准。
而使用
<c:redirect>
和
<c:param>
标签协作,由于包含在
<c:redirect>
标签体内的
<c:param>
标签可以有多个,因此显式地提供
<c:param>
标签就完成了给出转发参数的工作,即使用到
JavaBean
,也可以使用
EL
表达式来实现。
综上所述,利用
<c:redirect>
和
<c:param>
标签来代替
<logic:redirect
>
标签是有必要的。
相关推荐
#### JSTL与Struts结合的关键知识点 **一、JSTL简介** JSP Standard Tag Library (JSTL)是JavaServer Pages (JSP)的一个扩展,它提供了一系列预定义的标签,用于简化页面开发,提高代码可读性和可维护性。JSTL不是...
在实际开发中,开发者可以结合Struts和JSTL来创建高效的Java Web应用程序。Struts负责处理请求和业务逻辑,JSTL则在视图层简化页面开发。例如,可以使用Struts的ActionForm传递数据,然后在JSP页面上通过JSTL标签...
Struts标签库与JSTL(JavaServer Pages Standard Tag Library)是Java Web开发中的两个重要组件,它们极大地简化了HTML页面的编码工作,提升了代码的可读性和维护性。这两个库,尤其是jstl.jar和standard.jar,是...
两者之间的比较,Struts标签更专注于MVC框架中的控制器和视图部分,与Struts框架紧密结合,提供了更多与业务逻辑相关的功能。而JSTL则更为通用,适用于任何基于JSP的Web应用,它的标签设计更加标准化,易于学习和...
1. **JSTL与Struts的结合**:JSTL的Core标签库中的许多标签,如`<c:set>`、`<c:if>`、`<c:forEach>`等,可以用于Struts的视图层,帮助简化JSP页面的控制逻辑,使页面更加清晰,符合MVC的设计模式。同时,JSTL的fmt库...
Struts与JSTL的结合,使得Java Web开发更加高效和模块化。通过"struts-jstl 扎包",开发者可以快速搭建起一个支持两者集成的基础环境,从而专注于应用的功能实现。理解并熟练掌握这两项技术,对于提升Java Web开发...
在Struts框架中,JSTL可以与ActionForm、ModelDriven或ModelAndView模式结合使用,以展示由控制器层处理后的数据。例如,`<c:forEach>`标签可以用来遍历ActionForm或ModelDriven对象中的集合属性,展示在页面上: `...
4. **集成实践**:将Struts1.2、JSTL和JSP结合起来,创建一个完整的Web应用,比如用户登录、注册、数据展示等功能。 5. **最佳实践**:了解如何通过JSTL和EL减少脚本代码,提高JSP页面的可维护性,以及如何优化...
2. **JSTL HTML标签库**:这些标签提供了一种更优雅的方式来创建HTML表单元素,如`<html:form>`、`<html:text>`等,与Struts的动作标签相对应,但语法更简洁。 3. **JSTL XML标签库**:用于处理XML数据,例如解析...
Struts和JSTL是Java Web开发中两个重要的框架和库。Struts是一个基于MVC(Model-View-Controller)模式的开源框架,用于构建可维护性和可...通过深入研究,你可以将理论知识与实践相结合,更好地应对实际项目中的挑战。
**结合使用Struts和JSTL** 在实际开发中,Struts标签和JSTL标签经常一起使用,以增强视图层的功能。例如,Struts的`<html:form>`可以用于创建表单,而JSTL的`<c:forEach>`可以用来遍历列表并显示在表单中。同时,`...
总结来说,"Struts+Servlet+jstl 图书管理"是一个基于Java技术的图书管理系统,利用Struts框架实现MVC模式,Servlet处理请求和响应,JSP展示内容并结合JSTL简化页面编程。这个系统对于学习和理解Java Web开发有很好...
Struts2、JSTL、Spring、JavaScript(JS)以及JSP标签是Java Web开发中的核心组件,它们各自承担着不同的职责,共同构建了强大的Web应用程序。以下是对这些技术的详细解释: 1. **Struts2**:Struts2是一个基于MVC...
### JSTL、EL、ONGNL、Struts标签的区别与使用 #### 一、JSTL (JavaServer Pages Standard Tag Library) **定义**: JSTL 是一个由一系列标准标签组成的集合,这些标签可以帮助开发者简化 JavaServer Pages (JSP) ...
JSTL(JavaServer Pages Standard Tag Library...总的来说,JSTL和Struts结合使用,可以让我们编写更清晰、更易于维护的JSP页面。JSTL标签通过简化对Java对象的操作,使页面逻辑更加明确,提高了代码的可读性和复用性。
Struts2的核心是Action类,它处理用户请求,并与业务逻辑层交互。Action类返回的结果可以被不同的结果类型处理,如JSP页面或FreeMarker模板。在本示例中,Struts2负责接收用户的分页请求,控制数据的获取和页面的...
在实际开发中,尤其是与Struts等MVC框架结合使用时,JSTL能够有效地提升开发效率,降低维护难度,是Web开发中不可或缺的一部分。通过掌握JSTL的核心标签和其与其他技术的协同工作,可以构建出更加高效、清晰的Web...
标题"struts_jstl"可能指的是一个项目或教程,将Struts框架与JSTL标签库结合使用。通过访问提供的博客链接(https://shaqiang32.iteye.com/blog/201326),我们可以深入理解这两种技术的集成和应用。 首先,Struts...
6. **JSTL与Struts、Spring MVC比较**: 虽然JSTL提供了一种简化JSP的方式,但它主要用于页面展示逻辑,对于更复杂的业务逻辑处理,通常会配合Struts或Spring MVC这样的MVC框架来实现。 7. **JSTL的限制**: - 不...