Struts2标签库整理【完整】

时间:2021-04-13 14:33:18

转自:https://blog.csdn.net/chen_zw/article/details/8161230  

Struts2标签库提供了主题、模板支持,极大地简化了视图页面的编写,而且,struts2的主题、模板都提供了很好的扩展性。实现了更好的代码复用。Struts2允许在页面中使用自定义组件,这完全能满足项目中页面显示复杂,多变的需求。

头声明:<%@ taglib uri ="/struts-tags" prefix ="s" %>

struts2的标签可以分为五大类:

一、逻辑控制标签

(1)条件标签

条件标签主要有<s:if><s:elseif><s:esle>3个子标签,用于执行基本的条件流转

  1. <s:if test="#request.username=='admin'">
  2. 您是admin!
  3. </s:if>
  4. <s:elseif test="#request.username=='manager'">
  5. 您是manager!
  6. </s:elseif>
  7. <s:else>
  8. 您没有身份!
  9. </s:else>

test:条件判定语句,值为boolean类型。

(2)迭代标签

<s:iterator>标签用于遍历集合(java.util.Collection)或者枚举值(java.util.Iterator)类型的对象。

1、遍历普通List、数组

  1. //后台存放数据到list中
  2. List<String > list = newArrayList<String>();
  3. list.add("aaa");list.add("bbb"); list.add("ccc");
  4. <!-- 用iterator标签遍历list -- >
  5. <s:iterator value="list"var="v">
  6. <s:property value="v"/><br>
  7. </s:iterator>
  8. 或者:
  9. <s:iteratorvalue="list">
  10. <s:property/><br>
  11. </s:iterator>
2、遍历对象List、数组
  1. <s:iterator value="users" id="us">
  2. <!--可以这样: <s:property value="#us.name"/>  -->
  3. <s:property value="name"/>
  4. <s:property value="email"/><br/>
  5. </s:iterator>

3、 status属性的应用

  1. <s:iterator value="users" id="us" status="u">
  2. 序列号: <s:property value="#u.index"/>
  3. 姓名:  <s:property value="name"/>
  4. 邮件:  <s:property value="email"/>
  5. 是否第一条:  <s:property value="#u.first"/>
  6. 是否最后一条:<s:property value="#u.last"/>
  7. 是否偶数行:  <s:property value="#u.even"/>
  8. 是否奇数行:  <s:property value="#u.odd"/>
  9. 当前行数:    <s:property value="#u.count"/>
  10. </s:iterator>

id:指定集合中元素在值栈中的名称。
value:指定迭代的迭代体。
var:指向值栈中的值。
status:该属性在迭代时会产生一个IteratorStatus对象,该对象可以判断当前元素的位置。

二、数据输出标签

(1)action标签

<s:action>标签用于在jsp页面中直接调用Action

  1. <s:action name="loginAction"  namespace="/user" ignoreContextParam="false"  executeResult="true" >
  2. <s:param name="userName" value="'张三'"></s:param>
  3. </s:action>

name:struts.xml中指定Action的名称

executeResult:指定是否将Action的处理结果包含到本页面中.默认值为false(即不包含)

ignoreContextParam:指定该页面的请求参数是否需要传入调用的Action中,默认值是false(即传入参数)

注意:<s:param>是以request方式的值的,而不是以参数传值,所以request.getParameter("")会获取不到值,通过request.getAttribute("")方式可以获取到。

(2)date标签

<s:date>标签用以格式化日期并显示

  1. <s:date name="user.birth" format="yyyy-MM-dd HH:ss:mm"nice="false"/>

name:表示要输出的日期对象。

format:输出的日期格式。

nice:指定是否输出指定日期与当前时刻之间的时差。若nice="true",则format属性失效,只输出当前时刻与指定日期间的间隔;若nice=“false”,则是输出指定日期。

(3)bean标签

bean标签用于创建javaBean实例,需要java类提供相应的getter、setter方法

  1. <s:bean name="pojo.User" id = "user">
  2. <s:param name="name" value=" '张三' "></s:param>
  3. <s:param name="email" value=" '48964565@qq.com' "></s:param>
  4. <s:param name="age" value="20"/>
  5. <s:param name="birth" value="'2010-4-1'"/>
  6. </s:bean>
  7. <s:property value="#user.name"/>
  8. <s:property value="#user.email"/>
  9. <s:property value="#user.age"/>
  10. <s:date name="#user.birth" format="yyyy-MM-dd" nice="false"/>

name: 必填,指定要实例化的JavaBean的实现类

id
可选。如指定了该属性,则该Javabean实例会被放入StackContext中(不是ValueStack),从而允许直接通过该id属性来访问该JavaBean实例。如果未指定,则该Javabean实例会被放入ValueStack中,该标签结束,生成的子集被移出valuestack栈。

注意:java类String类型的属性赋值时,必须再加个单引号' '。

(4)parma标签

param标签用于为其他标签添加参数,用法如下:

  1. <!--  第一种用法 -->
  2. <s:param name="参数名" value="参数值"/>
  3. <!-- 第二种用法 -->
  4. <s:param name="参数名">参数值</s:param>

注意:字符串赋值时要加单引号。详见bean标签用法。

(5)property标签

property标签用于输出一个属性值。

  1. <s:property value="user.name" escape="false" default="默认值" />

value:指定属性的名称,默认值是栈顶元素。

escape:指定输出的内容是否要经过HTML转义,默认值是true。escape="false"表示会将类似"<h2>aaa</h2>"的字符串转义成html显示。

default:指定默认值。

(6)<s:url>标签<s:a>标签

<s:url>标签通常与<s:a>标签一起使用,<s:url>标签主要用于赋值給href属性,用于指定链接的地址和传递的参数。

  1. <!-- 指定链接的action 及 传递的参数 -->
  2. <s:url action="getUserList" namespace="test2" id="getUserListUrl" method="execute">
  3. <s:param name="id" value="1"></s:param>
  4. <s:param name="page" value="1"></s:param>
  5. </s:url>
  6. <!-- 链接地址引用了<s:url>的值 -->
  7. <s:a href="%{getUserListUrl}" >获取用户列表</s:a>

其结果等同于<a href="/test2/getUserList ! execute ?id = 1 & page = 1"></a>

(7)<s:debug>标签

<s:debug>标签用于在页面上生成一个连接,当点击链接时,可以看到ValueStack 和 Stack Context中的内容

三、HTML表单标签

(1)表单标签

  1. <s:form action=" " method="post" enctype="multipart/form-data" namespace="/test1">
  2. <s:textfield  label="姓名" name="username"  tooltip="Enter your Name here"  />
  3. <s:password label="密码"  name="password" />
  4. <s:textarea  label="备注" name="remark" cols="20" rows="3" tooltip="Enter your remark"/>
  5. <s:hidden name="topic.ic" value="<s:property value='topic.id'/>"></s:hidden>   //注意<s:property>标签的value值是单引号。
  6. <s:submit   value="提交"/>
  7. <s:reset  value="重置" />
  8. lt;/s:form>

enctype:共有3个值:

1)application/x-www-form-urlencoded:默认值,使用范围广,但向服务器发送大量文本、包含非ASCII字符的文本或二进制数据时该编码效率很低。

2)multipart/form-data:上传二进制数据,使用该值即可完整的传递文本文件数据。

3)text/plain:主要使用于发送电子邮件的应用。

namespace:设置action的包命名空间。

注意:当该标签设置了namespace属性后,action属性设置不能加.action后缀。

(2)<s:select>标签

  1. <!-- 数据前台设置 -->
  2. <s:select  label="性别"  name="gender" list="#{1:'男',2:'女'}"  listKey="key" listValue="value" value="#{2:'女'}" emptyOption="true" headerKey="-1"  headerValue="--请选择性别--"  tooltip="Choose your gender" />
  3. <!-- 数据后台获取 -->
  4. List<User> user;  //后台添加数据到list中
  5. <s:select  label="用户"  name="gender" list="user"  listKey="userId" listValue="name"  emptyOption="true" headerKey="-1"  headerValue="--请选择用户--"  tooltip="Choose your gender" />

list属性(必设):必须是一个可以迭代的源,如为一个List, Map, Set等

1)如果集合为javabean:<s:select theme="simple" name="sex" list="#request.sexs" listKey="id" listValue="name"></s:select>

2)如果集合为list:<s:select theme="simple" name="sexList" list="{'男','女'}"></s:select>

3)如果集合为map:<s:select theme="simple" name="sexMap" list="#{1:'男',2:'女'}" listKey="key" listValue="value"></s:select>

listKey:设置后台传送的数据项。

listValue:设置前台显示的数据项。

emptyOption:设置是否有空选项。

value:设置默认显示数据列表list中的选项。

headerValue:设置下拉框头条显示数据。

headerKey:设置下拉框头条后台传回的数据。

(3)<s:combobox>标签

  1. <s:combobox theme="simple" label="选择你喜欢的颜色" name="colorNames"  headerValue="------请选择------" headerKey="1"  list="{'红','橙','黄','绿','青','蓝','紫'}" />

属性说明详见<s:select>标签。

(4)<s:checkboxlist>标签

  1. <s:checkboxlist name="hobby" label="兴趣"  list="#{1:'football', 2:'music',3:'basketball', 4:'computer'}" listKey="key" listValue="value" tooltip="Choose your hobby"/>

属性说明详见<s:select>标签。

(5)<s:checkbox>标签

  1. <s:checkbox name="age" label="年龄" value="18"  fieldValue="yes" tooltip="Confirmed that your are Over 18"/>

fieldVaule:设置选中时向后台传送的数据(默认不设时返回的是布尔类型)。

value:设置前台显示的数据。

(6)<s:radio>标签

  1. <s:radio list="#{1:'男',2:'女'}" name="gender" label="性别" required="true" value="1"></s:radio>

value:默认选中的选项的key值。

(7)<s:file>标签

  1. <s:file label="上传" theme="simple" name="uploadfile"/>

(8)<s:hidden>标签

  1. <s:hidden name="uid"/>

四、HTML非表单标签

(1)<s:actionerror>标签

actionerror标签用于输出存储在ActionError中的值。

<s:actionerror/>

Action类中添加actionerror信息:addActionError("出错了!");

(2)<s:actionmessage>标签

actionmessage标签用于输出存储在ActionMessage中的值。

<s:actionmessage/>

Action类中添加actionmessage信息:addActionMessage("出错了!");

(3)<s:fielderror>标签

fielderror标签用于输出FieldError中的值。默认错误信息显示在所对应field标签的上方。

<s:textfield name="user.name" label="姓名" />

Action类中添加fielderror信息:addFieldError("user.name", "用户名不能为空!");

注意:(1)
actionerror与actionmessage功能差不多,不过在<head></head>中加上<s:head/>标签后,actionerror和fielderror的错误信息有CSS效果(变红),而actionmessage无效果。

(2) 在添加错误信息前最好先clearErrorsAndMessages();来清空之前加载的错误信息。

五、AJAX标签

<%@taglib prefix="sx" uri="/struts-dojo-tags" %>

记得在<head></head>中加上<sx:head/>标签,<sx:head/>标签 用来下载Dojo文件和相应的Javascript代码

(1)<sx:div>标签

<sx:div>标签可以异步定时加载刷新数据。

  1. <!-- 用于显示异步加载的数据 -->
  2. <div id="msg">
  3. <s:property value="message"/>
  4. </div>
  5. <!-- 定时5s加载test2.action中的message属性值,并刷新id=“msg”的div标签-->
  6. <sx:div updateFreq="5000" href="test2/test2.action" delay="100" errorText="出错了!" loadingText="正在请求..." showLoadingText="true" indicator="msg">
  7. </sx:div>

href:异步请求的资源地址。

updateFreq:自动更新div内容的间隔,以毫秒为单位。

autoStart:页面加载后是否启动定时器,默认为true。

delay:第一个异步请求开始之前等待的时间,以毫秒为单位。

loadText:当请求正在处理时显示的文本。

showLoadingText:是否显示loadText值,默认为false。

errorText:当请求失败时显示的文本。

indicator:当请求正在处理时具有这个id的元素将被显示。

executeScript:执行服务器返回内容中的javascript代码,默认为false。

formId:指定表单id,表单字段将被序列化并作为参数传递。

(2)<sx:a>标签

  1. <!-- 单击"用户信息列表信息" 链接后会加载userList.jsp表到userListDiv标签上,其中getUserList.action是跳转到userList.jsp页面的 -->
  2. <sx:a href="test2/getUserList.action"  targets="userListDiv" loadingText="加载中..." showLoadingText="true" errorText="加载失败!">用户信息列表</sx:a>
  3. <div id="userListDiv"></div>
  4. <!-- userList.jsp -->
  5. <body>
  6. <table border="1" cellpadding="0" cellspacing="0">
  7. <thead>
  8. <tr>
  9. <th colspan="4">用户信息列表</th>
  10. </tr>
  11. </thead>
  12. <tbody>
  13. <tr>
  14. <th>序列号</th>
  15. <th>用户名</th>
  16. </tr>
  17. <s:iterator value="users" id="us" status="u">
  18. <tr>
  19. <td><s:property value="#u.index"/></td>
  20. <td><s:property value="name"/></td>
  21. </tr>
  22. </s:iterator>
  23. </tbody>
  24. </table>
  25. </body>

href:异步请求的资源地址。

targets:被更新的元素列表。

loadText:当请求正在处理时显示的文本。

showLoadingText:是否显示loadText值,默认为false。

errorText:当请求失败时显示的文本。

indicator:当请求正在处理时具有这个id的元素将被显示。

executeScript:执行服务器返回内容中的javascript代码,默认为false。

formId:指定表单id,表单字段将被序列化并作为参数传递。

(3)<sx:submit>标签

<sx:submit>标签的使用和<sx:a>标签的使用一样,这里就不举例了。

(4)<sx:datetimepicker>标签

  1. <sx:datetimepicker name="book.publicationDate" value="today" label="出版日期" displayFormat="yyyy-MM-dd" ></sx:datetimepicker>

(5)<sx:textarea>标签

  1. <sx:textarea name="user.remark"  label="备注"  rows="20" cols="50"></sx:textarea>

提示:<sx:textarea>标签提交的文本是带Html标签的。

(6)<sx:tree>标签

  1. <sx:tree label="城市" id="city" showRootGrid="false" showGrid="false" treeSelectedTopic="treeSelected">
  2. <sx:treenode label="北京" id="bj">
  3. <sx:treenode label="朝阳" id="cy"></sx:treenode>
  4. <sx:treenode label="中关村" id="zgc"></sx:treenode>
  5. </sx:treenode>
  6. <sx:treenode label="天津" id="tj">
  7. <sx:treenode label="白洋淀" id="byd"></sx:treenode>
  8. </sx:treenode>
  9. </sx:tree>
  10. <script language="JavaScript" type="text/javascript">
  11. dojo.event.topic.subscribe("treeSelected", function treeNodeSelected(node) {
  12. alert(node.node.widgetId + node.node.title);
  13. });
  14. </script>

showRootGrid:是否显示根节点,默认为true。

showGrid:是否显示结点间的连接线,默认为true。

treeSelectedTopic:选中时的时间。

(7)<sx:tabbedpanel>标签

  1. <sx:tabbedpanel id="tab1" cssStyle="width:300px;" labelposition="top" selectedTab="tab2">
  2. <sx:div  id="tab1" label="Tab 1" cssStyle="height:100px;" href="index.jsp" closable="true" preload="false" >
  3. Local Tab 1
  4. </sx:div>
  5. <sx:div id="tab2"  label="Tab 2" cssStyle="height:100px;" href ="index.jsp"  refreshOnShow="true">
  6. Local Tab 2
  7. </sx:div>
  8. <sx:div id="tab3"  label="Tab 3" disabled="true">
  9. Local Tab 3
  10. </sx:div>
  11. </sx:tabbedpanel>

closable:设置该tab标签是否可关闭。

href:加载资源。若为jsp页面,则加载该页面到该tab中。

preload:设置是否预先加载,默认为true。

cssStyle:用于设置tab选项卡大小。

refreshOnShow:设置是否每次单击选项卡重新加载内容,默认为false。

disabled:设置选项卡是否失效,默认为false。

labelposition:设置选项卡标头的显示位置,可以是top, right, bottom, left。

selectedTab:设置默认选中的选项卡。