本来使用JSTL完全就能满足项目的需要,还是sun的标准技术,具有更好的移植性,使用Struts标签的一个最主要的功能就是数据回显。
property标签
property标签用于输出指定值:
<s:set name="name"value="'kk'" />
<s:propertyvalue="#name"/>
default:可选属性,如果需要输出的属性值为null,则显示该属性指定的值
escape:可选属性,指定是否格式化HTML代码。
value:可选属性,指定需要输出的属性值,如果没有指定该属性,则默认输出ValueStack栈顶的值。
id:可选属性,指定该元素的标识
iterator标签
iterator标签用于对集合进行迭代,这里的集合包含List、Set和数组。
<s:set name="list"value="{'zhangming','xiaoi','liming'}" />
<s:iteratorvalue="#list" status="st">
<fontcolor=<s:iftest="#st.odd">red</s:if><s:else>blue</s:else>>
<s:property/></font><br>
</s:iterator>
value:可选属性,指定被迭代的集合,如果没有设置该属性,则使用ValueStack栈顶的集合。
id:可选属性,指定集合里元素的id。
status:可选属性,该属性指定迭代时的IteratorStatus实例。该实例包含如下几个方法:
intgetCount(),返回当前迭代了几个元素。
intgetIndex(),返回当前迭代元素的索引。
booleanisEven(),返回当前被迭代元素的索引是否是偶数
booleanisOdd(),返回当前被迭代元素的索引是否是奇数
booleanisFirst(),返回当前被迭代元素是否是第一个元素。
booleanisLast(),返回当前被迭代元素是否是最后一个元素。
if/elseif/else标签
<s:set name="age"value="21" />
<s:iftest="#age==23">
23
</s:if>
<s:elseiftest="#age==21">
21
</s:elseif>
<s:else>
都不等
</s:else>
url标签
<s:url action="helloworld_add"namespace="/test"><s:param name="personid"value="23"/></s:url>
生成类似如下路径:
/struts/test/helloworld_add.action?personid=23
红色部分为内容路径。
当标签的属性值作为字符串类型处理时, “%”符号的用途是计算OGNL表达式的值。
<s:set name="myurl"value="'http://www.foshanshop.net'"/>
<s:url value="#myurl" /><br>
<s:url value="%{#myurl}"/>
输出结果:
#myurl
http://www.foshanshop.net
表单标签_checkboxlist复选框
如果集合为list
<s:checkboxlistname="list" list="{'Java','.Net','RoR','PHP'}" value="{'Java','.Net'}"/>
生成如下html代码:
<input type="checkbox"name="list" value="Java"checked="checked"/><label>Java</label>
<input type="checkbox"name="list" value=".Net"checked="checked"/><label>.Net</label>
<input type="checkbox"name="list" value="RoR"/><label>RoR</label>
<input type="checkbox"name="list" value="PHP"/><label>PHP</label>
如果集合为MAP
<s:checkboxlist name="map"list="#{1:'瑜珈用品',2:'户外用品',3:'球类',4:'自行车'}"listKey="key"listValue="value" value="{1,2,3}"/>
生成如下html代码:
<input type="checkbox"name="map" value="1"checked="checked"/><label>瑜珈用品</label>
<input type="checkbox"name="map" value="2"checked="checked"/><label>户外用品</label>
<input type="checkbox"name="map" value="3"checked="checked"/><label>球类</label>
<input type="checkbox"name="map" value="4"/><label>自行车</label>
如果集合里存放的是javabean
<%
Person person1 = new Person(1,"第一个");
Person person2 = new Person(2,"第二个");
List<Person> list = new ArrayList<Person>();
list.add(person1);
list.add(person2);
request.setAttribute("persons",list);
%>
<s:checkboxlistname="beans" list="#request.persons"listKey="personid"listValue="name"/>
Personid和name为Person的属性
生成如下html代码:
<input type="checkbox"name=“beans" value="1"/><label>第一个</label>
<input type="checkbox"name=“beans" value="2"/><label>第二个</label>
表单标签_radio单选框
该标签的使用和checkboxlist复选框相同。
如果集合里存放的是javabean(personid和name为Person的属性)
< s:radio name="beans" list="#request.persons"listKey="personid"listValue="name"/>
生成如下html代码:
<input type="radio"name="beans" id="beans1"value="1"/><label>第一个</label>
<input type="radio"name="beans" id="beans2"value="2"/><label>第二个</label>
如果集合为MAP
<s:radio name="map" list="#{1:'瑜珈用品',2:'户外用品',3:'球类',4:'自行车'}"listKey="key" listValue="value“ value="1"/>
生成如下html代码:
<input type="radio"name="map" id="map1" value="1"/><labelfor="map1">瑜珈用品</label>
<input type="radio"name="map" id="map2" value="2"/><labelfor="map2">户外用品</label>
<input type="radio"name="map" id="map3" value="3"/><labelfor="map3">球类</label>
<input type="radio"name="map" id="map4" value="4"/><labelfor="map4">自行车</label>
如果集合为list
<s:radio name="list" list="{'Java','.Net'}"value="'Java'"/>
生成如下html代码:
<input type="radio"name="list" checked="checked"value="Java"/><label>Java</label>
<input type="radio"name="list" value=".Net"/><label>.Net</label>
表单标签_select下拉选择框<s:select name="list" list="{'Java','.Net'}"value="'Java'"/>
<select name="list"id="list">
<option value="Java"selected="selected">Java</option>
<option value=".Net">.Net</option>
</select>
<s:select name="beans" list="#request.persons"listKey="personid"listValue="name"/>
<select name="beans"id="beans">
<option value="1">第一个</option>
<option value="2">第二个</option>
</select>
<s:select name="map" list="#{1:'瑜珈用品',2:'户外用品',3:'球类',4:'自行车'}"listKey="key" listValue="value" value="1"/>
<select name="map"id="map">
<option value="1" selected="selected">瑜珈用品</option>
<option value="2">户外用品</option>
<option value="3">球类</option>
<option value="4">自行车</option>
</select>
Struts2的防止表单重复提交
<s:token />标签防止重复提交,用法如下:
第一步:在表单中加入<s:token />
<s:form action="helloworld_other" method="post"namespace="/test">
<s:textfield name="person.name"/><s:token/><s:submit/>
</s:form>
第二步:
<action name="helloworld_*" class="cn.itcast.action.HelloWorldAction" method="{1}">
<interceptor-ref name="defaultStack" />//利用的是token拦截器的功能
<interceptor-ref name="token" />
<result name="invalid.token">/WEB-INF/page/message.jsp</result>
<result>/WEB-INF/page/result.jsp</result>
</action>
以上配置加入了“token”拦截器和“invalid.token”结果,因为“token”拦截器在会话的token与请求的token不一致时,将会直接返回“invalid.token”结果。
在debug状态,控制台出现下面信息,是因为Action中并没有struts.token和struts.token.name属性,我们不用关心这个错误:
严重: ParametersInterceptor - [setParameters]: Unexpected Exception caught setting 'struts.token' on 'class xxx: Error settingexpression 'struts.token' with value '[Ljava.lang.String;@39f16f'
严重: ParametersInterceptor - [setParameters]: Unexpected Exception caught setting'struts.token.name'