空間站

          北極心空

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            15 Posts :: 393 Stories :: 160 Comments :: 0 Trackbacks

           Struts 2為大家提供了不少常用的很酷的表單標(biāo)志,簡化了我們程序員的工作。不過,由于這些都是新標(biāo)志,大家可能在使用上還存在不少疑問。本文將就朋友們的回復(fù)、留言或Email上的問題,分別對這些酷標(biāo)志進(jìn)行講述。

          表單標(biāo)志使用小技巧

          Struts 2的表單標(biāo)志在輸出(render)HTML時,使用了模板的概念,增加了復(fù)雜性(因為它不像Struts 1.x的表單標(biāo)志,它通常都是一個標(biāo)志對應(yīng)HTML的一個元素),因此大家在使用時,需要一些技巧:

          1. Struts 2的UI標(biāo)志的表單標(biāo)志默認(rèn)是以表格布局,按鈕是右對齊的。如果你不喜歡此風(fēng)格,你可以簡單地將<s:form />標(biāo)志的“theme”屬性設(shè)為“simple”,然后用以往的做法自已布局表單元素(注意:此法有利有弊,弊就是當(dāng)你將“theme”屬性設(shè)為“simple”時,表單標(biāo)志以最簡單方式輸出HTML,所以你可能失去一些默認(rèn)輸出提供的便利,如:友好的錯誤信息的顯示,或客戶端的表單驗證等)。當(dāng)然更好的做法是通過CSS或自定義主題(theme)然后應(yīng)用到整個應(yīng)用程序,這樣可以獲得一致的頁面風(fēng)格,加強(qiáng)用戶體驗(我會在以后的文章對此進(jìn)行講解);
          2. 當(dāng)你在頁面上加入某些標(biāo)志(如:<s:doubleselect />等)時,應(yīng)該通過action來訪問頁面,而不是通過*.jsp的URL直接訪問。

          下面我將分別對這些標(biāo)志進(jìn)行講述:

          1、<s:checkboxlist />

          大家對<s:checkboxlist />的最大的疑問可能是:“如何在默認(rèn)情況下,選中某些checkbox?”

          答案其實(shí)很簡單,只需要將其“value”屬性設(shè)為你的要選中的值,如以代碼所示:

          <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8" %>
          <%@ taglib prefix="s" uri="/struts-tags" %>

          <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
          <html xmlns="http://www.w3.org/1999/xhtml">
          <head>
             
          <title>Struts 2 Cool Tags - &lt;s:checkboxlist/ &gt;</title>
             
          <s:head />
          </head>
          <body>    
             
          <h2>&lt;s:checkboxlist/&gt;</h2>
             
          <s:form action="Store" >
                 
          <s:checkboxlist name="skills1" 
                                  label
          ="Skills 1" 
                                  list
          ="{ 'Java', '.Net', 'RoR', 'PHP' }" 
                                  value
          ="{ 'Java', '.Net' }" />
                 
          <s:checkboxlist name="skills2" 
                                  label
          ="Skills 2" 
                                  list
          ="#{ 1:'Java', 2: '.Net', 3: 'RoR', 4: 'PHP' }" 
                                  listKey
          ="key" 
                                  listValue
          ="value" 
                                  value
          ="{ 1, 2, 3 }"/>
             
          </s:form>
          </body>
          </html>
          清單1 WebContent/checkboxlist.jsp

          分布運(yùn)行應(yīng)用程序,在瀏覽器中鍵入:http://localhost:8080/Struts2_CoolTags/checkboxlist.jsp,出現(xiàn)如下圖所示頁面:

          checkboxlist.jsp頁面
          清單2 checkboxlist.jsp頁面

          2、<s:doubleselect />

          大家看Struts 2的showcase的例子,<s:doubleselect />的用法如下所示:

              <s:doubleselect
                     
          tooltip="Choose Your State"
                      label
          ="State"
                      name
          ="region" list="{'North', 'South'}"
                      value
          ="'South'"
                      doubleValue
          ="'Florida'"
                      doubleList
          ="top == 'North' ? {'Oregon', 'Washington'} : {'Texas', 'Florida'}" 
                      doubleName
          ="state"
                      headerKey
          ="-1"
                      headerValue
          ="---------- Please Select ----------"
                      emptyOption
          ="true" />
          清單3 Showcase中<s:doubleselect />

          很多朋友問:“上面的‘list’屬性只有兩個值,如果我有三個或更多的值,‘doublelist’屬性應(yīng)該如何設(shè)定呢?”

          我建議的做法是先定義一個Map類型的對象,鍵為“list”的集合,值則為“doubleList”的集合,然后“doubleList”的OGNL寫成“#myMap[top]”,如以下代碼所示:

          <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8" %>
          <%@ taglib prefix="s" uri="/struts-tags" %>

          <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
          <html xmlns="http://www.w3.org/1999/xhtml">
          <head>
             
          <title>Struts 2 Cool Tags - &lt;s:doubeselect/ &gt;</title>
             
          <s:head />
          </head>
          <body>    
             
          <h2>&lt;s:doubleselect/&gt;</h2>
             
          <s:form action="Store" >
                 
          <s:set name="foobar" 
                         value
          ="#{'Java': {'Spring', 'Hibernate', 'Struts 2'}, '.Net': {'Linq', ' ASP.NET 2.0'}, 'Database': {'Oracle', 'SQL Server', 'DB2', 'MySQL'}}" />
                 
          <s:doubleselect list="#foobar.keySet()"
                                    doubleName
          ="technology" 
                                    doubleList
          ="#foobar[top]" 
                                    label
          ="Technology" />
             
          </s:form>
          </body>
          </html>
          清單4 WebContent/doubleselect.jsp

          分布運(yùn)行應(yīng)用程序,在瀏覽器中鍵入:http://localhost:8080/Struts2_CoolTags/doubleselect.action,出現(xiàn)如下圖所示頁面:

          doubleselect.jsp頁面
          清單5 doubleselect.jsp頁面

          3、<s: token />

          這個標(biāo)志可能大家不常用,不過本人認(rèn)為它還是挺有用的。在使用Struts 1.x時,因為跳轉(zhuǎn)通常是用Forward(而不是Redirect)實(shí)現(xiàn)的,所以當(dāng)用戶完成請求后,按“F5”刷新頁面時,就會重新提交上次的請求,這樣經(jīng)常會出錯。要解決這個問題,<s:token />可以幫你忙。

          實(shí)現(xiàn)原理

          在頁面加載時,<s: token />產(chǎn)生一個GUID(Globally Unique Identifier,全局唯一標(biāo)識符)值的隱藏輸入框如:

          <input type="hidden" name="struts.token.name" value="struts.token"/>
          <input type="hidden" name="struts.token" value="BXPNNDG6BB11ZXHPI4E106CZ5K7VNMHR"/>
          清單6 <s:token />的HTML輸出

          同時,將GUID放到會話(session)中;在執(zhí)行action之前,“token”攔截器將會話token與請求token比較,如果兩者相同,則將會話中的token刪除并往下執(zhí)行,否則向actionErrors加入錯誤信息。如此一來,如果用戶通過某種手段提交了兩次相同的請求,兩個token就會不同。

          具體實(shí)現(xiàn)

          首先看一下Action的代碼:

          package tutorial;

          import com.opensymphony.xwork2.ActionSupport;

          public class CoolTagAction extends ActionSupport {    
             
          private static final long serialVersionUID = 6820659617470261780L;
             
             
          private String message;
                 
             
          public String getMessage() {
                 
          return message;
             }


             
          public void setMessage(String message) {
                 
          this.message = message;
             }

             
             @Override
             
          public String execute() {
                 System.out.println(
          "Executing action, your message is " + message);
                 
          return SUCCESS;
             }
             
          }
          清單7 src/tutorial/CoolTagAction.java

          以上代碼一目了然,再看看JSP的寫法:

          %@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8" %>
          <%@ taglib prefix="s" uri="/struts-tags" %>

          <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
          <html xmlns="http://www.w3.org/1999/xhtml">
          <head>
             
          <title>Struts 2 Cool Tags - &lt;s:token/ &gt;</title>
             
          <s:head />
          </head>
          <body>    
             
          <h2>&lt;s:token/&gt;</h2>
             
          <s:actionerror />
             
          <s:form action="Token" >
                 
          <s:textfield name="message" label="Message" />
                 
          <s:token />
                 
          <s:submit />
             
          </s:form>
          </body>
          </html>
          清單8 WebContent/token.jsp

          JSP也很簡單,就是加入<s:token />標(biāo)志。接下來是Actoin配置的XML片段:

          <?xml version="1.0" encoding="UTF-8"?>

          <!DOCTYPE struts PUBLIC
              "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
              "http://struts.apache.org/dtds/struts-2.0.dtd"
          >

          <struts>
             
          <package name="Struts2_COOL_TAGS_DEMO" extends="struts-default">
                 
          <action name="Token" class="tutorial.CoolTagAction">
                     
          <interceptor-ref name="defaultStack" />
                     
          <interceptor-ref name="token" />
                     
          <result name="invalid.token">/token.jsp</result>                        
                     
          <result>/token.jsp</result>
                 
          </action>
                 
          <action name="*">
                     
          <result>/{1}.jsp</result>
                 
          </action>
             
          </package>
          </struts>
          清單9 src/struts.xml

          以上XML片段值注意的是加入了“token”攔截器和“invalid.token”結(jié)果,因為“token”攔截器在會話token與請求token不一致時,將會直接返回“invalid.token”結(jié)果。

          發(fā)布運(yùn)行應(yīng)用程序,在瀏覽器中鍵入:http://localhost:8080/Struts2_CoolTags/token.jsp,出現(xiàn)如下圖所示頁面:

          正常顯示的token.jsp頁面
          清單10 正常顯示的token.jsp頁面

          隨便填點(diǎn)東西并提交頁面,一切正常返回以上頁面,然后按“F5”刷新頁面,在彈出的對話框中點(diǎn)擊“Retry”,出現(xiàn)如下圖所示頁面:

          重復(fù)提交出錯顯示
          清單11 重復(fù)提交出錯顯示

          4、<s:datetimepicker />、<s:optiontransferselect />和<s:updownselect />

          這幾個標(biāo)志的使用相對簡單,所以我想小舉一例即可,以下是JSP的代碼:

          <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
          <html xmlns="http://www.w3.org/1999/xhtml">
          <head>
             
          <title>Struts 2 Cool Tags - Others</title>
             
          <s:head />
          </head>
          <body>    
             
          <h2>Others</h2>
             
          <s:form action="Store" >
                 
          <s:datetimepicker name="birthday" label="Birthday" />
                 
          <s:updownselect
                     
          label = "Favourite Countries"
                      list
          ="#{'england':'England', 'america':'America', 'germany':'Germany'}"
                      name
          ="prioritisedFavouriteCountries"
                      headerKey
          ="-1"
                      headerValue
          ="--- Please Order Them Accordingly ---"
                      emptyOption
          ="true" />
                 
          <s:optiontransferselect            
                     
          label="Favourite Cartoons Characters"
                      name
          ="leftSideCartoonCharacters" 
                      leftTitle
          ="Left Title"
                      rightTitle
          ="Right Title"
                      list
          ="{'Popeye', 'He-Man', 'Spiderman'}" 
                      multiple
          ="true"
                      headerKey
          ="headerKey"
                      headerValue
          ="--- Please Select ---"
                      emptyOption
          ="true"
                      doubleList
          ="{'Superman', 'Mickey Mouse', 'Donald Duck'}" 
                      doubleName
          ="rightSideCartoonCharacters"
                      doubleHeaderKey
          ="doubleHeaderKey"
                      doubleHeaderValue
          ="--- Please Select ---" 
                      doubleEmptyOption
          ="true"
                      doubleMultiple
          ="true" />
             
          </s:form>
          </body>
          </html>
          清單12 WebContent\others.jsp頁面

          發(fā)布運(yùn)行應(yīng)用程序,在瀏覽器中鍵入:http://localhost:8080/Struts2_CoolTags/others.jsp,出現(xiàn)如下圖所示頁面:

          點(diǎn)擊查看大圖
          清單13 其它表單標(biāo)志頁面

          總結(jié)

          Struts 2在標(biāo)志上的確比Struts 1.x豐富了許多,同時模板機(jī)制也給程序員帶來不少方便(如果你不太喜歡個性化的風(fēng)格)。另外,Struts 2還有一些AJAX(如<s: autocompleter />等)的標(biāo)志和非表單的UI標(biāo)志(如<s: tree />等),我會在以后的文章中講述其使用。


          原作者:http://www.aygfsteel.com/max/archive/2007/05/18/118442.html
          posted on 2008-03-04 10:30 蘆葦 閱讀(601) 評論(0)  編輯  收藏 所屬分類: Struts
          主站蜘蛛池模板: 乐亭县| 隆化县| 蓬溪县| 丰县| 肥东县| 铁岭市| 洛扎县| 天镇县| 崇阳县| 雷山县| 龙井市| 晴隆县| 精河县| 胶州市| 将乐县| 芜湖市| 如皋市| 习水县| 武隆县| 襄城县| 乐平市| 普兰店市| 睢宁县| 岳西县| 阳高县| 昌江| 沅陵县| 兰溪市| 修文县| 湖南省| 临邑县| 星座| 邹平县| 墨竹工卡县| 吉木萨尔县| 石门县| 山西省| 德安县| 湖北省| 普定县| 中江县|