Struts2常用標簽總結
Struts2常用標簽總結 一 介紹 1.Struts2的作用 Struts2標簽庫提供了主題、模板支持,極大地簡化了視圖頁面的編寫,而且,struts2的主題、模板都提供了很好的擴展性。實現了更好的代碼復用。Struts2允許在頁面中使用自定義組件,這完全能滿足項目中頁面顯示復雜,多變的需求。 Struts2的標簽庫有一個巨大的改進之處,struts2標簽庫的標簽不依賴于任何表現層技術,也就是說strtus2提供了大部分標簽,可以在各種表現技術中使用。包括最常用的jsp頁面,也可以說Velocity和FreeMarker等模板技術中的使用 2.Struts2分類 (1)UI標簽:(User Interface, 用戶界面)標簽,主要用于生成HTML元素標簽,UI標簽又可分為表單標簽非表單標簽 (2)非UI標簽,主要用于數據訪問,邏輯控制等的標簽。非UI標簽可分為流程控制標簽(包括用于實現分支、循環等流程控制的標簽)和數據訪問標簽(主要包括用戶輸出ValueStack中的值,完成國際化等功能的) (3)ajax標簽 3.Struts2標簽使用前的準備: (1)在要使用標簽的jsp頁面引入標簽庫: <%@ taglib uri="/struts-tags" prefix="s"%> (2)在web.xml中聲明要使用的標簽 這樣是struts2 2.3.1.2版本的引入方式 <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> 4.標簽的使用 (1)property標簽 用于輸出指定的值: <s:property value="%{@cn.csdn.hr.domain.User@Name}"/><br/> <s:property value="@cn.csdn.hr.domain.User@Name"/><Br/><!-- 以上兩種方法都可以 --> <s:property value="%{@cn.csdn.hr.domain.User@study()}"/> 以上可以訪問某一個包的類的屬性的集中方式,study()是訪問方法的方法,并輸出。 以下用java代碼代替的,訪問某一個范圍內的屬性 <% //采用pageContext對象往page范圍內存入值來 驗證#attr搜索順序是從page開始的 ,搜索的順序為:page,reques,session,application。 set存值的時候存到的是request中,在jsp頁面中訪問的時候不用加任何的標識符,即可直接訪問,如果不同的作用域不一樣了, pageContext.setAttribute("name", "laoowang", PageContext.PAGE_SCOPE); %> <s:property value="#attr.name" /> 假設在action中設置了不同作用域的類 不同的作用域的標簽的訪問: <h3>獲取的是requet中的對象值</h3> 第一種方式:<s:property value="#request.user1.realName"/> <br/> 第二種方式:<s:property value="#request.user1['realName']"/> <br/> 第三種方式:<s:property value="#user1.realName"/> <br/> 第四種方式:<s:property value="#user1['realName']"/> <br/> 第五種方式:${requestScope.user1.realName } || ${requestScope.user1['realName'] } 第六種:<s:property value="#attr.user1.realName"/> attr對象按page==> request sessionapplictio找的 <h3>獲取session中的值</h3> 第一種方式:<s:property value="#session.user1.realName"/> <br/> 第二種方式:<s:property value="#session.user1['realName']"/> 第五種方式:${sessionScope.user1.realName } || ${sessionScope.user1['realName'] } <h3>獲取application中的對象的值</h3> 第一種方式:<s:property value="#application.user1.realName"/> <br/> 第二種方式:<s:property value="#application.user1['realName']"/> 第五種方式:${applicationScope.user1.realName } || ${applicationScope.user1['realName'] } (2)iterator標簽的使用 第一種:list集合 <!-- 設置set集合 value--> <!-- status 可選屬性,該屬性指定迭代時的IteratorStatus實例 --> <!-- value="#attr.list" list存放到了request中 可以value="#request.list" statu.odd返回當前被迭代元素的索引是否是奇數 --> <s:set name="list" value="{'a','b','c','d'}"></s:set> <s:iterator var="ent" value="#request.list" status="statu"> <s:if test="%{#statu.odd}"> <font color="red"><s:property value="#ent" /> </font> </s:if> <s:else> <s:property value="#ent" /> </s:else> </s:iterator> 第二種:map集合中的使用 <h3>Map集合</h3> <!-- map集合的特點: 語法格式:# {key:value,key1:value1,key2:value2,.....} 以上的語法中就直接生成了一個Map類型的集合,該Map對象中的每個key-value對象之間用英文的冒號隔開 ,多個元素之間用逗號分隔。 --> </div> <s:set var="map" value="#{'1':'laowang','2':'老王','3':'猩猩'}"></s:set> 遍歷Map: <br /> <s:iterator value="#map"> <s:property value="key" />:::<s:property value="value" /> <Br /> </s:iterator>\ 第三種:集合的變量 <h3>遍歷集合:::</h3> <div> <!-- 遍歷出價格大于3000的 --> <s:iterator var="user" value="#session['users']"> <s:if test="%{#user['price']>3000}"> <s:property value="#user['price']"/> </s:if> </s:iterator> <hr color="blue"/><!-- $是取出價格 大于3000的最后一個值 --> <s:iterator var="u" value="#session.users.{$(#this['price']>3000)}"> <s:property value="price"/> </s:iterator> </div> 注:users是User的對象,price是User中的一個屬性 簡述一下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(),返回當前被迭代元素是否是最后一個元素。 (3)if 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> (4)URL標簽 <!-- 聲明一個URL地址 --> <s:url action="test" namespace="/tag" var="add"> <s:param name="username">laowangang</s:param> <s:param name="id">12</s:param> </s:url> <s:a href="%{add}">測試URL</s:a> <s:a action="test" namespace="/tag"></s:a> 以上的兩個<s:a>標簽的作用是一樣的。 (5)data標簽 <% pageContext.setAttribute("birth",new Date(200,03,10),PageContext.REQUEST_SCOPE); %> <s:date name="#request.birth" format="yyyy年MM月dd日"/> <s:date name="#request.birth" nice="true"/> 這個標簽是按照format的格式去輸出的。 (6)表單 <h1>from表單</h1> <s:form action="test" namespace="/tag"> <s:textfield label="用戶名" name="uname" tooltip="你的名字" javascriptTooltip="false"></s:textfield> <s:textarea name="rmake" cols="40" rows="20" tooltipDelay="300" tooltip="hi" label="備注" javascriptTooltip="true"></s:textarea> <s:password label="密碼" name="upass"></s:password> <s:file name="file" label="上傳文件"></s:file> <s:hidden name="id" value="1"></s:hidden> <!-- <select name="edu"> <option value="listKey">listValue</option> --> <s:select list="#{'1':'博士','2':'碩士'}" name="edu" label="學歷" listKey="key" listValue="value"></s:select> <s:select list="{'java','.net'}" value="java"></s:select><!-- value是選中的 --> <!-- 必須有name --> <s:checkbox label="愛好 " fieldValue="true" name="checkboxFiled1"></s:checkbox> <!-- 多個checkbox --> <s:checkboxlist list="{'java','css','html','struts2'}" label="喜歡的編程語言" name="box" value="{'css','struts2'}"></s:checkboxlist> <!-- map集合前要加# --> <s:checkboxlist list="#{1:'java',2:'css',3:'html',4:'struts2',5:'spring'}" label="喜歡的編程語言" name="boxs" value="{1,2}"></s:checkboxlist> <!-- listKey listValue <input type="text" name="boxs" value="listKey">顯示值listValue --> <!-- radio --> <% //從服務器傳過來值 pageContext.setAttribute("sex","男",PageContext.REQUEST_SCOPE); pageContext.setAttribute("sex1","男",PageContext.REQUEST_SCOPE); %> <s:radio list="{'男','女'}" name="sex" value="#request.sex"></s:radio> <s:radio list="#{1:'男',2:'女'}" name="sex1" listKey="key" listValue="value" value="#request.sex1"></s:radio> <!-- 防止表單提交的方式 --> <s:token></s:token> <s:submit value="提交"></s:submit> </s:form>
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!