1 Property标签
(1)、说明
用于输出指定的值
(2)、属性
default:可选属性,如果输出的值为null,则显示该属性指定的值。
ecape:选属性,指定是否格式化为html代码
vlue:选属性,指定需要输出的属性值,如果没有指定该属性,则默认输出ValueStack栈顶的值。
在testOgnlTag.jsp中
利用property标签获取栈顶的值:
<br>
<a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testProperty1.action">测试</a>
在OgnlTagAction中
public String testProperty1(){
return "ognlTag";
}
在successOgnlTag.jsp中:
利用property标签获取栈顶的值:<br>
<s:property/> //没有value属性,所以应该输出的是栈顶元素
结果:
cn.itcast.struts2.action.ognltag.OgnlTagAction@5a82b2
(4)、例2(default和value)
在testOgnlTag.jsp中 测试property中的default的值:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testDefault.action">测试</a><br> 在OgnlTagAction中 public String testDefault() { ServletActionContext.getRequest().setAttribute("request_username", "username"); return "ognlDefault"; } 在successOgnlTag.jsp中 当property的value没有值的情况下,输出default的值:<br> <s:property value="#request.request_username11" default="default value"/> <s:property value="#request.request_username" default="default value"/> 说明:因为在后台request中的key值为.request_username,而页面上的输出为.request_username11,不对应,所以应该输出default的值。 |
在testOgnlTag.jsp中: 测试property中的escape的值:<br> <s:property value="%{'<hr>hr的解析'}"/> 说明:因为escapse默认的值为true,也就是说<hr>hr的解析会当作一个字符串处理。 <s:property value="%{'<hr>hr的解析'}" escape=”false”/> 说明:因为如果escapse为false,则把字符串中符合html标签的语法,会当作html标签来进行处理。 |
(6)、例4(输出栈顶String的值)
在testOgnlTag.jsp中: 取出栈顶的值:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testString.action">测试</a><br> 在OgnlTagAction中 public String testString(){ ActionContext.getContext().getValueStack().push("msg"); return "ognlString"; } 在successOgnlTag中 取出栈顶的值:<br> <s:property/> |
2 Debug标签
(1)、说明
利用debug标签可以输出OGNLContext所有的值
(2)、例子
在testOgnlTag.jsp中: 利用debug标签输出ognl的所有的值:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testDebug.action">测试</a><br> 在OgnlTagAction中 public String testDebug(){ return "ognlDebug"; } 在successOgnlTag.jsp中: 利用debug标签输出OgnlContext中所有的值:<br> <s:debug></s:debug>//利用这个标签可以输出ognlcontext中所有的值 |
3 Set标签
(1)、说明
用于将某个指定的值放入到指定的范围
(2)、属性
var:变量的名字,name、id与var表达的含义是一样的。Var已经取代了name,id;
Scope:指定变量被放置的范围。该属性可以接受application,session,request,page或 Action。如果没有设置该属性,则默认会放在action中。
Value:赋值给变量的值。如果没有设置该属性,则将ValueStack栈顶的值赋给变量。
(3)、例1
在testOgnlTag.jsp中 测试set标签:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testSet.action">测试</a><br> 在OgnlTagAction中 public String testSet() { ServletActionContext.getRequest().setAttribute("request_username", "username"); return "ognlSet"; } 在successOgnlTag.jsp中 测试set标签:<br> <s:set value="#request.request_username" var="aaaaa" scope="request"></s:set> <s:property value="#request.aaaaa"/> 说明:这样的情况,aaaaa的key值会出现在request域中。 <s:set value="#request.request_username" var="aaaaa"></s:set> <s:property value="#request.aaaaa"/> 说明:这种写法aaaaa会作为一个key值存在ognl的map中。所以利用 <s:property value="#aaaaa"/>也能输出值。
|
4 Push标签
(1)、说明
把对象放入到栈顶,不能放入到其他的范围,当标签结束时,会从栈顶删除。
(2)、例子
在testOgnlTag.jsp中 用push方法把一个对象放入到栈顶:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testPUSH.action">测试</a><br> 在OgnlTagAction中 public String testPUSH(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); return "ognlPUSH"; } 在successOgnlTag.jsp中 利用push方法把对象放入到栈顶:<br> <s:push value="#request.request_username"> <s:property/> <s:debug></s:debug>//注意debug标签的位置,这个位置是正确的 </s:push> <s:debug></s:debug>//这个位置的标签是错误的。因为s:push标签已经结束,所以栈顶元素已经被删除掉了。 |
5 Bean标签
(1)、说明
实例化一个符合javabean规范的class,标签体内可以包含几个param元素,可用于调用set方法,给class的属性赋值。
(2)、属性
Name:要被实例化的class的名字,符合javabean规范。
Var: 赋值给变量的值。放置在request作用域中。如果没有设置该属性,对象被设置到栈顶。
(3)、例子
在testOgnlTag.jsp中 利用bean标签实例化一个person对象:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testBean.action">测试</a><br> 在OgnlTagAction中 public String testBean(){ ServletActionContext.getRequest().setAttribute("pid", 1); ServletActionContext.getRequest().setAttribute("request_username", "username"); ServletActionContext.getRequest().setAttribute("pname", "username"); ServletActionContext.getRequest().setAttribute("comment", "person"); return "ognlBean"; } 在successOgnlTag.jsp中 给一个person赋值,值来自于后台:<br> <s:bean name="cn.itcast.struts2.valuestack.bean.Person" var="myperson"> <s:param name="pid" value="#request.pid"></s:param> <s:param name="pname" value="#request.pname"></s:param> <s:param name="comment" value="#request.comment"></s:param> <!--因为person在栈顶,所以输出栈顶--> <s:property value="pid"/> <s:property value="pname"/> <s:property value="comment"/> <s:debug></s:debug> </s:bean> <s:property/>//值不再是Person对象 <!— 前提条件:不加var=”myperson”属性由于bean标签在栈顶,所以当bean标签结束的时候, 栈顶的person对象就被删除掉了。所以在bean标签的外部输出栈顶的person值是不行的。 --> |
<s:property/> <!-- 当bean标签中加var属性值为myperson,用debug标签再观察其值的分布情况 在map中出现了"myperson":person对象 --> <s:property value="#person.pid"/><br> <s:property value="#person.pname"/><br> <s:property value="#person.comment"/><br> 说明:当加上var=”myperson”属性的时候,myperson对象出现在了map中,这个时候就可以在bean标签的外部获取person的属性了。 |
(1)、说明
通过指定命名空间和action的名称,可以直接调用后台的action.
(2)、属性
Name: Aciton的名字
Namespace: Action所在的命名空间(action的名称后不加.action)
executeResult: Action的result是否需要被执行,默认值为false,不执行
(3)、例子
在testOgnlTag.jsp中 通过action标签访问后台的action:<br> <s:action name="ognlTagAction_testBean" namespace="/ognl" executeResult="true"></s:action> 说明: 如果executeResult的属性值为false,会执行到相应的action,但是action跳转后的页面 将不再执行。如果executeResult的属性值为true,则会在当前页面包含跳转后的页面 值。 |
7 Iterator标签
(1)、说明
该标签用于对集合进行迭代。这里的集合包括:list,set和数组
(2)、属性
Value:可选属性,指定被迭代的集合。如果没有设置该属性,则使用对象栈顶的集合。
Var:可选属性,引用变量的名称
Status:可选属性,该属性指定迭代时的IteratorStatus实例。该实例包含如下的方法:
int getCount() 返回当前迭代的元素个数
int getIndex() 返回当前迭代元素的索引
boolean isEven() 返回当前迭代元素的索引是否是偶数
boolean isOdd() 返回当前迭代元素的索引是否是奇数
boolean isFirst() 返回当前迭代元素是否为第一个元素
boolean isLast() 返回当前迭代元素是否为最后一个元素
(3)、例1(push)
在testOgnlTag.jsp中 通过iterator标签把后台的list集合遍历(list通过push方法压入到栈顶)<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testList1.action">测试</a><br> 在OgnlTagAction中 /* * 把生成的list利用push方法压入到栈顶 */ public String testList1(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); List<Person> personList = new ArrayList<Person>(); List<Person> person1List = new ArrayList<Person>(); for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); personList.add(person); }
for(int i=11;i<15;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); person1List.add(person); }
|
/* * 说明: * 1、执行完三次压栈以后,对象栈的栈顶存放的元素为String类型的aaa; * 而这个时候如果页面用<s:iterator value="top"></s:iterator> * top代表对象栈的栈顶的元素 * 进行迭代的时候,针对的元素是aa 2、执行第一次压栈和第二次压栈,对象栈的栈顶存放的元素为person1List; * 页面上用 * <s:iterator value="top"></s:iterator> * top代表对象栈的栈顶的元素 * 进行迭代的时候,针对的元素是person1List; * 3、执行第一次压栈,对象栈的栈顶存放的元素为personList; * 页面上用 * <s:iterator value="top"></s:iterator> * top代表对象栈的栈顶的元素 * 进行迭代的时候,针对的元素是personList; */ //把personList压入到栈顶 ActionContext.getContext().getValueStack().push(personList); /* * 把perosn1List压入到栈顶 */ ActionContext.getContext().getValueStack().push(person1List); /* * 把aaa压入到栈顶 */ ActionContext.getContext().getValueStack().push("aaa"); return "ognlList1"; }
在successOgnlTag.jsp中 用iterator标签迭代后台list中的数据(把list通过push方法压入到栈顶 ):<br> <!-- 因为iterator是一个迭代器标签,value的属性值top代表栈顶的元素 --> <s:iterator value="top"> <s:property value="pname"/> <s:property/>//可以输出对象栈栈顶的元素 <s:debug></s:debug>//输出OgnlContext的结构 </s:iterator><br> <s:debug></s:debug>//当iterator迭代完之后观察OgnlContext的结构 说明:当进行迭代的时候,当前的被迭代的对象会被放入到栈顶,所以在property元素输出的时候不用加#号。当iterator标签结束的时候,栈顶的对象会被删除掉。 |
(4)、例2(action属性)
在testOgnlTag.jsp中 通过iterator标签把后台的list集合遍历(list作为action中的属性)<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testList2.action">测试</a><br> 在OgnlTagAction中 private List<Person> pList; public List<Person> getPList() { return pList; } public void setPList(List<Person> list) { pList = list; } public String testList2(){ ServletActionContext.getRequest().setAttribute("request_username", "username");//在successOgnlTag.jsp中 <s:push value="#request.request_username">标签需要用到后台的这个操作。 this.pList = new ArrayList<Person>(); for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); pList.add(person); } return "ognlList2"; } 说明:通过代码可以看出来,这个例子中把pList作为action的属性,然后给其赋值。 在successOgnlTag.jsp中 用iterator标签迭代后台list中的数据(list作为action中的属性 ):<br> <s:iterator value="pList"> <s:property value="pname"/> <s:property/> <s:debug></s:debug> </s:iterator><br> <s:debug></s:debug> 说明:因为OgnlTagAction在对象栈,所以value中的pList可以不加#号。从第一个debug标签可以看出,这个标签把当前正在迭代的对象临时放入到了栈顶。如果iterator元素结束迭代时,栈顶的对象就消失了。所以第一次的debug和第二次的 Debug内容是不一样的。 |
(5)、例3(Map中)
在testOgnlTag.jsp中 通过iterator标签把后台的list集合遍历(list通过ActionContext.getContext().put放入OgnlContext的Map中)<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testList3.action">测试</a><br> 在OgnlTagAction中 /* * 把personList通过put方法放入到OnglContext的map中 */ public String testList3(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); List<Person> personList = new ArrayList<Person>(); for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); personList.add(person); } ActionContext.getContext().put("personList", personList); return "ognlList3"; } 在successOgnlTag.jsp中 用iterator标签迭代后台list中的数据(list经过ActionContext.getContext().put方法放入到OgnlContext中 ):<br> <s:iterator value="personList"> <s:property value="pname"/> <s:property/> <s:debug></s:debug> </s:iterator><br> <s:debug></s:debug> 说明:用iterator进行迭代,迭代的集合如果来自map,value的值可以加#也可以不加#,这点需要注意。Debug的现象和例2一样。 |
(6)、例4(begin,end,step)
在testOgnlTag.jsp中 利用iterator的begin、end、step属性控制数据的显示:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testList4.action">测试</a><br> 在OgnlTagAction中 /* * 在页面上通过iterator的begin,end,step属性控制页面的显示 */ public String testList4(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); List<Person> personList = new ArrayList<Person>(); for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); personList.add(person); } ServletActionContext.getRequest().setAttribute("first", 2); ServletActionContext.getRequest().setAttribute("end", 8); ServletActionContext.getRequest().setAttribute("step", 2); ActionContext.getContext().put("personList", personList); return "ognlList4"; } 在successOgnlTag.jsp中 用iterator标签属性begin,end,step控制数据的显示:<br> <s:iterator value="personList" begin="%{#request.first}" end="%{#request.end}" step="%{#request.step}"> <s:property value="pname"/><br> <s:property/><br> </s:iterator><br> 说明:begin属性为开始位置,end属性为结束位置,step为步长。这里要注意begin的值是通过ognl表达式传递过来的。 |
(7)、例5(status)
在testOgnlTag.jsp中 测试iterator的status属性:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testList5.action">测试</a><br> 在OgnlTagAction中 /* * 测试iterator的status属性 */ public String testList5(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); List<Person> personList = new ArrayList<Person>(); for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); personList.add(person); } ActionContext.getContext().put("personList", personList); return "ognlList5"; } 在successOgnlTag.jsp中 测试iterator的status属性的值:<br> <!-- 如果提供status 每次迭代时候将生成一个IteratorStatus实例并放入堆栈中 用debug标签查看堆栈,在map中,存在一个st,类型为org.apache.struts2.views.jsp.IteratorStatus st对应一个IteratorStatus对象,有如下属性 int getCount() 返回当前迭代的元素个数 int getIndex() 返回当前迭代元素的索引 boolean isEven() 返回当前迭代元素的索引是否是偶数 boolean isOdd() 返回当前迭代元素的索引是否是奇数 boolean isFirst() 返回当前迭代元素是否为第一个元素 boolean isLast() 返回当前迭代元素是否为最后一个元素--> <table border="1"> <s:iterator value="personList" var="person" status="st"> <tr> <td><s:property value="#st.count"/></td> <td><s:property value="#st.getIndex()"/></td> <td><s:property value="#person.pname"/></td> </tr> </s:iterator> </table>
<br> |
说明:上述标明status属性,就会在栈中的map中有一个key值为st,而st对应的值为org.apache.struts2.views.jsp.IteratorStatus的对象。在迭代每一个元素的时候,都存在这个对象,我们可以根据这个对象获取到该对象的属性。从而得到遍历中的相关信息。 |
testOgnlTag.jsp 利用iterator的status属性完成隔行变色:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testList6.action">测试</a><br> OgnlTagAction /* * 利用iterator的status属性完成表格的隔行变色 */ public String testList6(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); List<Person> personList = new ArrayList<Person>(); for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); personList.add(person); } ActionContext.getContext().put("personList", personList); return "ognlList6"; } successOgnlTag.jsp <style type="text/css"> .odd{ background-color:red; } .even{ background-color:blue; } </style> |
利用iterator的status属性隔行变色:<br> <table border="1"> <s:iterator value="personList" var="person" status="st"> <!-- value的值可以跟双目表达式 --> <tr class="<s:property value="#st.even?'even':'odd'"/>"> <td><s:property value="#st.count"/></td> <td><s:property value="#st.getIndex()"/></td> <td><s:property value="#st.isEven()"/></td> <td><s:property value="#st.isOdd()"/></td> <td><s:property value="#st.isFirst()"/></td> <td><s:property value="#st.isLast()"/></td> <td><s:property value="#person.pid"/></td> <td><s:property value="#person.pname"/></td> </tr> </s:iterator> </table> 说明:<s:property value="#st.even?'even':'odd'"/>这是一个双目表达式。 |
8 If/elseif/else标签
(1)、说明
基本的流程控制标签。If标签可以单独使用,也可以结合elseif或else标签使用。
(2)、属性
test:后面跟判断表达式。
(3)、例子
testOgnlTag.jsp 测试if/elseif/else标签的使用:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testIF.action">测试</a><br> OgnlTagAction /* * 测试if标签 */ public String testIF(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); List<Person> personList = new ArrayList<Person>(); for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); personList.add(person); } ActionContext.getContext().put("personList", personList); return "ognlIF"; } successOgnlTag.jsp 测试if/elseif/else标签:<br> <table border="1"> <s:iterator value="personList" var="person" status="st"> <!-- value的值可以跟双目表达式 --> <tr class="<s:property value="#st.even?'even':'odd'"/>"> <td><s:property value="#person.pid"/></td> <td><s:property value="#person.pname"/></td> <td> <s:if test="#person.pid<3">这个id号小于3</s:if> <s:elseif test="#person.pid<5">这个id号大于等于3小于5</s:elseif> <s:else>这个id号大于等于5</s:else> </td> </tr> </s:iterator> </table> |
9 url标签
(1)、说明
该标签用于创建url,可以通过”param”标签提供request参数。
(2)、属性
Value:
如果没有值,就用当前的action,使用value后必须加.action.
Action:
用来生成url的action.如果没有使用则用value;
Namespace:
命名空间
Var:
引用变量的名称。
testOgnlTag.jsp 测试url标签的使用:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testURL.action">测试</a><br> OgnlTagAction /* * 测试标签url */ public String testURL(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); return "ognlURL"; } |
successOgnlTag.jsp 测试url标签的使用:<br> <!-- 作用:直接输出url地址 --> <s:url action="ognlTagAction.action" namespace="/ognl" var="myurl"> <s:param name="pid" value="12"></s:param> <s:param name="pname" value="%{'zd'}"></s:param> </s:url> <s:debug></s:debug> <a href="<s:property value="#myurl"/>">test</a> 说明:如果url标签不写var属性,则url标签输出url的路径。如果写上var变量, 则会在OgnlContext中出现相应的key值:myurl。所以在程序的最后一行引用了 #myurl变量从而得到路径。Param是传递的参数。这里需要注意: value="%{'zd'}可以,但是value=”zd”是不行的。后面的写法会去栈顶查找zd。 所以s:url标签就相当于声明一个url,然后在外部使用。 |
10 Ognl操作集合
Java代码 |
OGNL表达式 |
list.get(0) |
List[0] |
array[0] |
array[0] |
((User)list.get(0)).getName() |
list[0].name |
Array.length |
Array.length |
List.size() |
List.size |
List.isEmpty() |
List.isEmpty |
testOgnlTag.jsp 测试集合的长度:<br> <a href="${pageContext.request.contextPath}/ognl/ognlTagAction_testListLength.action">测试</a><br> OgnlTagAction /* * 测试集合的长度 */ public String testListLength(){ ServletActionContext.getRequest().setAttribute("request_username", "username"); List<Person> personList = new ArrayList<Person>(); |
for(int i=0;i<10;i++){ Person person = new Person(); person.setPid(i); person.setPname("person"+i); person.setComment("person"+i); personList.add(person); } ActionContext.getContext().put("personList", personList); return "ognlListLength"; } successOgnlTag.jsp 测试集合的长度:<br> <s:property value="#personList.size"/> 直接写一个集合:<br> <s:iterator value="{1,2,3,4}"> <s:property/> </s:iterator> |
11 Ognl操作Map
Java代码 |
Ognl表达式 |
|
map.get(“foo”) |
Map[‘foo’] |
|
Map.get(new Integer(1)); |
Map[1] |
|
User user = (User)map.get(“user”); Return user.getName() |
Map[‘user’].name |
|
Map.size() |
Map.size |
|
Map.isEmpty() |
Map.isEmpty |
|
Map.get(“foo”) |
Map.foo |
|
Map map = new HashMap(); Map.put(“foo”,”bar”); Map.put(“1”,”2”); Return map; |
#{“foo”:”bar”,”1”:”2”} |
|
Map map = new HashMap(); Map.put(new Integer(1),”a”); Map.put(new Integer(2),”b”); Map.put(new Integer(3),”c”); |
#{1:”a”,2:”b”,3:”c”} |
testOgnlTag.jsp 写一个map集合:<br> <s:iterator value="#{1:'a',2:'b',3:'c'}"> <!-- 获取map中的key和value --> <s:property value="value"/> <s:property value="key"/> <s:debug></s:debug> </s:iterator> <br> <s:iterator value="#{1:'a',2:'b',3:'c'}" var="map"> <!-- 获取map中的key和value --> <s:property value="value"/><br> <s:property value="key"/><br> <s:property value="#map.value"/><br> </s:iterator> |
12. UI标签
说明
UI标签在html文件中表现为一个表单元素。
使用struts2的ui标签有如下好处:
可以进行表单的回显
对页面进行布局和排版
标签的属性可以被赋值为一个静态的值,或者一个OGNL表达式。
Form标签
说明
id属性为s:form的唯一标识。可以用document.getElementById()获取。
name属性为s:form的名字,可以用document.getElementsById()获取。
在默认情况下,s:form将显示表格的形式。
Textfield标签
说明
实际上相当于在表格中多了一行,在这行中多了两列。其变化从上述图中可以很明显的看出。
Password标签
说明
如果不加showPassword属性,则密码不会显示,把showPassword属性的值设置为true,就能显示密码。
Hidden标签
说明
Hidden标签并没有加tr和td
Submit标签
(1)、情况一
a.说明一
这种情况为submit的type属性为submit类型。
(2)、情况二:
b.说明二
这种情况submit的type属性为button.
(3)、情况三
c.说明三
该type类型为image。
(4)、综合
以上三种情况说明,当type为submit、button、image都能完成提交。
Reset标签
Textarea标签
Checkbox标签
如果集合为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>
Checkboxlist标签
如果集合里存放的是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>
(1)、 集合为list
(2)、集合为map
listKey相当于<input type=”checkbox”>中的value,listValue相当于label的显示值。
(3)、List中是javabean
13标签回显
BackValueAction:
private String username = "aaa";
private String password = "bbb";
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
Backvalue.jsp
14.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>
15. 表单标签_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>
16. <s:token />标签防止重复提交
<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.csdn.action.HelloWorldAction" method="{1}">
<interceptor-ref name="defaultStack" />
<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与请求的:
严重: ParametersInterceptor - [setParameters]: Unexpected Extoken不一致时,将会直接返回“invalid.token”结果。
在debug状态,控制台出现下面信息,是因为Action中并没有struts.token和struts.token.name属性,我们不用关心这个错误ception caught setting 'struts.token' on 'class xxx: Error setting expression 'struts.token' with value '[Ljava.lang.String;@39f16f'
严重: ParametersInterceptor - [setParameters]: Unexpected Exception caught setting 'struts.token.name'