property标签



property标签用于输出指定值:

<s:set name="name" value="'kk'" />

<s:property value="#name"/>

default:可选属性,如果需要输出的属性值为null,则显示该属性指定的值

escape:可选属性,指定是否格式化HTML代码。

value:可选属性,指定需要输出的属性值,如果没有指定该属性,则默认输出ValueStack栈顶的值。

id:可选属性,指定该元素的标识






iterator标签



iterator标签用于对集合进行迭代,这里的集合包含List、Set和数组。

<s:set name="list" value="{'zhangming','xiaoi','liming'}" />

<s:iterator value="#list" status="st">

<font color=<s:if test="#st.odd">red</s:if><s:else>blue</s:else>>

<s:property /></font><br>

</s:iterator>
value:可选属性,指定被迭代的集合,如果没有设置该属性,则使用ValueStack栈顶的集合。
id:可选属性,指定集合里元素的id。
status:可选属性,该属性指定迭代时的IteratorStatus实例。该实例包含如下几个方法:
• int getCount(),返回当前迭代了几个元素。
• int getIndex(),返回当前迭代元素的索引。
• boolean isEven(),返回当前被迭代元素的索引是否是偶数
• boolean isOdd(),返回当前被迭代元素的索引是否是奇数
• boolean isFirst(),返回当前被迭代元素是否是第一个元素。
• boolean isLast(),返回当前被迭代元素是否是最后一个元素。

if/elseif/else标签


<s:set name="age" value="21" />
<s:if test="#age==23">
23
</s:if>
<s:elseif test="#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}" />

 





表单标签_checkboxlist复选框



如果集合为list

<s:checkboxlist name="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:checkboxlist name="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"/><label for="map1">瑜珈用品</label>
<input type="radio" name="map" id="map2" value="2"/><label for="map2">户外用品</label>
<input type="radio" name="map" id="map3" value="3"/><label for="map3">球类</label>
<input type="radio" name="map" id="map4" value="4"/><label for="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>