大家好,欢迎来到IT知识分享网。
Struts2标签库提供了主题、模板支持,极大地简化了视图页面的编写,而且,struts2的主题、模板都提供了很好的扩展性。实现了更好的代码复用。Struts2允许在页面中使用自定义组件,这完全能满足项目中页面显示复杂,多变的需求。
头声明:<%@ taglib uri ="/struts-tags" prefix ="s" %>
struts2的标签可以分为五大类:
一、逻辑控制标签
(1)条件标签
条件标签主要有<s:if><s:elseif><s:esle>3个子标签,用于执行基本的条件流转
<s:if test="#request.username=='admin'">
您是admin!
</s:if>
<s:elseif test="#request.username=='manager'">
您是manager!
</s:elseif>
<s:else>
您没有身份!
</s:else>
test:条件判定语句,值为boolean类型。
(2)迭代标签
<s:iterator>标签用于遍历集合(java.util.Collection)或者枚举值(java.util.Iterator)类型的对象。
1、遍历普通List、数组
//后台存放数据到list中
List<String > list = newArrayList<String>();
list.add("aaa");list.add("bbb"); list.add("ccc");
<!-- 用iterator标签遍历list -- >
<s:iterator value="list"var="v">
<s:property value="v"/><br>
</s:iterator>
或者:
<s:iteratorvalue="list">
<s:property/><br>
</s:iterator>
<s:iterator value="users" id="us">
<!--可以这样: <s:property value="#us.name"/> -->
<s:property value="name"/>
<s:property value="email"/><br/>
</s:iterator>
3、 status属性的应用
<s:iterator value="users" id="us" status="u">
序列号: <s:property value="#u.index"/>
姓名: <s:property value="name"/>
邮件: <s:property value="email"/>
是否第一条: <s:property value="#u.first"/>
是否最后一条:<s:property value="#u.last"/>
是否偶数行: <s:property value="#u.even"/>
是否奇数行: <s:property value="#u.odd"/>
当前行数: <s:property value="#u.count"/>
</s:iterator>
id:指定集合中元素在值栈中的名称。
value:指定迭代的迭代体。
var:指向值栈中的值。
status:该属性在迭代时会产生一个IteratorStatus对象,该对象可以判断当前元素的位置。
二、数据输出标签
(1)action标签
<s:action>标签用于在jsp页面中直接调用Action
<s:action name="loginAction" namespace="/user" ignoreContextParam="false" executeResult="true" >
<s:param name="userName" value="'张三'"></s:param>
</s:action>
name:struts.xml中指定Action的名称
executeResult:指定是否将Action的处理结果包含到本页面中.默认值为false(即不包含)
ignoreContextParam:指定该页面的请求参数是否需要传入调用的Action中,默认值是false(即传入参数)
注意:<s:param>是以request方式的值的,而不是以参数传值,所以request.getParameter(“”)会获取不到值,通过request.getAttribute(“”)方式可以获取到。
(2)date标签
<s:date>标签用以格式化日期并显示
<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方法
<s:bean name="pojo.User" id = "user">
<s:param name="name" value=" '张三' "></s:param>
<s:param name="email" value=" '48964565@qq.com' "></s:param>
<s:param name="age" value="20"/>
<s:param name="birth" value="'2010-4-1'"/>
</s:bean>
<s:property value="#user.name"/>
<s:property value="#user.email"/>
<s:property value="#user.age"/>
<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标签用于为其他标签添加参数,用法如下:
<!-- 第一种用法 -->
<s:param name="参数名" value="参数值"/>
<!-- 第二种用法 -->
<s:param name="参数名">参数值</s:param>
注意:字符串赋值时要加单引号。详见bean标签用法。
(5)property标签
property标签用于输出一个属性值。
<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属性,用于指定链接的地址和传递的参数。
<!-- 指定链接的action 及 传递的参数 -->
<s:url action="getUserList" namespace="test2" id="getUserListUrl" method="execute">
<s:param name="id" value="1"></s:param>
<s:param name="page" value="1"></s:param>
</s:url>
<!-- 链接地址引用了<s:url>的值 -->
<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)表单标签
<s:form action=" " method="post" enctype="multipart/form-data" namespace="/test1">
<s:textfield label="姓名" name="username" tooltip="Enter your Name here" />
<s:password label="密码" name="password" />
<s:textarea label="备注" name="remark" cols="20" rows="3" tooltip="Enter your remark"/>
<s:hidden name="topic.ic" value="<s:property value='topic.id'/>"></s:hidden> //注意<s:property>标签的value值是单引号。
<s:submit value="提交"/>
<s:reset value="重置" />
</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>标签
<!-- 数据前台设置 -->
<s:select label="性别" name="gender" list="#{1:'男',2:'女'}" listKey="key" listValue="value" value="#{2:'女'}" emptyOption="true" headerKey="-1" headerValue="--请选择性别--" tooltip="Choose your gender" />
<!-- 数据后台获取 -->
List<User> user; //后台添加数据到list中
<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>标签
<s:combobox theme="simple" label="选择你喜欢的颜色" name="colorNames" headerValue="------请选择------" headerKey="1" list="{'红','橙','黄','绿','青','蓝','紫'}" />
属性说明详见<s:select>标签。
(4)<s:checkboxlist>标签
<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>标签
<s:checkbox name="age" label="年龄" value="18" fieldValue="yes" tooltip="Confirmed that your are Over 18"/>
fieldVaule:设置选中时向后台传送的数据(默认不设时返回的是布尔类型)。
value:设置前台显示的数据。
(6)<s:radio>标签
<s:radio list="#{1:'男',2:'女'}" name="gender" label="性别" required="true" value="1"></s:radio>
value:默认选中的选项的key值。
(7)<s:file>标签
<s:file label="上传" theme="simple" name="uploadfile"/>
(8)<s:hidden>标签
<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>标签可以异步定时加载刷新数据。
<!-- 用于显示异步加载的数据 -->
<div id="msg">
<s:property value="message"/>
</div>
<!-- 定时5s加载test2.action中的message属性值,并刷新id=“msg”的div标签-->
<sx:div updateFreq="5000" href="test2/test2.action" delay="100" errorText="出错了!" loadingText="正在请求..." showLoadingText="true" indicator="msg">
</sx:div>
href:异步请求的资源地址。
updateFreq:自动更新div内容的间隔,以毫秒为单位。
autoStart:页面加载后是否启动定时器,默认为true。
delay:第一个异步请求开始之前等待的时间,以毫秒为单位。
loadText:当请求正在处理时显示的文本。
showLoadingText:是否显示loadText值,默认为false。
errorText:当请求失败时显示的文本。
indicator:当请求正在处理时具有这个id的元素将被显示。
executeScript:执行服务器返回内容中的javascript代码,默认为false。
formId:指定表单id,表单字段将被序列化并作为参数传递。
(2)<sx:a>标签
<!-- 单击"用户信息列表信息" 链接后会加载userList.jsp表到userListDiv标签上,其中getUserList.action是跳转到userList.jsp页面的 -->
<sx:a href="test2/getUserList.action" targets="userListDiv" loadingText="加载中..." showLoadingText="true" errorText="加载失败!">用户信息列表</sx:a>
<div id="userListDiv"></div>
<!-- userList.jsp -->
<body>
<table border="1" cellpadding="0" cellspacing="0">
<thead>
<tr>
<th colspan="4">用户信息列表</th>
</tr>
</thead>
<tbody>
<tr>
<th>序列号</th>
<th>用户名</th>
</tr>
<s:iterator value="users" id="us" status="u">
<tr>
<td><s:property value="#u.index"/></td>
<td><s:property value="name"/></td>
</tr>
</s:iterator>
</tbody>
</table>
</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>标签
<sx:datetimepicker name="book.publicationDate" value="today" label="出版日期" displayFormat="yyyy-MM-dd" ></sx:datetimepicker>
(5)<sx:textarea>标签
<sx:textarea name="user.remark" label="备注" rows="20" cols="50"></sx:textarea>
提示:<sx:textarea>标签提交的文本是带Html标签的。
(6)<sx:tree>标签
<sx:tree label="城市" id="city" showRootGrid="false" showGrid="false" treeSelectedTopic="treeSelected">
<sx:treenode label="北京" id="bj">
<sx:treenode label="朝阳" id="cy"></sx:treenode>
<sx:treenode label="中关村" id="zgc"></sx:treenode>
</sx:treenode>
<sx:treenode label="天津" id="tj">
<sx:treenode label="白洋淀" id="byd"></sx:treenode>
</sx:treenode>
</sx:tree>
<script language="JavaScript" type="text/javascript">
dojo.event.topic.subscribe("treeSelected", function treeNodeSelected(node) {
alert(node.node.widgetId + node.node.title);
});
</script>
showRootGrid:是否显示根节点,默认为true。
showGrid:是否显示结点间的连接线,默认为true。
treeSelectedTopic:选中时的时间。
(7)<sx:tabbedpanel>标签
<sx:tabbedpanel id="tab1" cssStyle="width:300px;" labelposition="top" selectedTab="tab2">
<sx:div id="tab1" label="Tab 1" cssStyle="height:100px;" href="index.jsp" closable="true" preload="false" >
Local Tab 1
</sx:div>
<sx:div id="tab2" label="Tab 2" cssStyle="height:100px;" href ="index.jsp" refreshOnShow="true">
Local Tab 2
</sx:div>
<sx:div id="tab3" label="Tab 3" disabled="true">
Local Tab 3
</sx:div>
</sx:tabbedpanel>
closable:设置该tab标签是否可关闭。
href:加载资源。若为jsp页面,则加载该页面到该tab中。
preload:设置是否预先加载,默认为true。
cssStyle:用于设置tab选项卡大小。
refreshOnShow:设置是否每次单击选项卡重新加载内容,默认为false。
disabled:设置选项卡是否失效,默认为false。
labelposition:设置选项卡标头的显示位置,可以是top, right, bottom, left。
selectedTab:设置默认选中的选项卡。
转载请注明转自本文,原文链接地址:http://blog.csdn.net/czw2010/article/details/8161230
参考:
[1] http://struts.apache.org/docs/tag-reference.html
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/26603.html