<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Struts標簽庫詳解(1)

    Struts提供了五個標簽庫,即:HTMLBeanLogicTemplateNested
    標簽庫
    說明
    HTML 標簽
    用來創建能夠和Struts 框架和其他相應的HTML 標簽交互的HTML 輸入表單
    Bean 標簽
    在訪問JavaBeans 及其屬性,以及定義一個新的bean 時使用
    Logic 標簽
    管理條件產生的輸出和對象集產生的循環
    Template 標簽
    隨著Tiles框架包的出現,此標記已開始減少使用
    Nested 標簽
    增強對其他的Struts 標簽的嵌套使用的能力
    標簽的公共特征
    使用固定屬性名稱的Struts 標簽:
    屬性
    說明
    id
    命名自定義標簽創建時的腳本變量名。
    name
    指出關鍵字值,在該關鍵字下可以找到一個存在的bean 。如果給出了scope屬性,則僅僅在scope中查找。否則,根據標準的順序在各種scope中查找:(page, request, session, or application)
    property
    指出bean 中的某個屬性,可以在其中檢索值。如果沒有標明,則使用對象本身的值。
    scope
    定義了Bean在哪個范圍(page, request, session, or application)中被查找。如果沒有標明按順序查找。腳本變量(id)將在相同的范圍中創建。
    Struts 標簽也支持嵌套引用,例如:
    Property="foo.bar.baz"

    這相當于進行下面的調用:
    getFoo().getBar().getBaz()


    或者做為setter
    getFoo().getBar().setBaz(value)
    雖然Struts 標簽的設計原意是為了避免使用scriptletscriptlet的表達式還能夠提供給所有的Struts 標簽使用。但請確保使用完整的表達式:
    錯誤:
    <html:link href="'<%= "/" + name %>/index.jsp>'>

    正確:
    <html:link href="'<%= "/" + name + "/index.jsp" %>'>    //
    表達式必須提供整個屬性值

    Html 標簽庫
    1.        <html>標簽
    它有兩個屬性:localexhtml,兩者都不是必需的。
    <html:html locale=\"true\">

    此行代碼解析后:
    <html lang=\"en\">
    2.        說明:生成的結果取決于Struts應用程序所位于的服務器的locale。如果你將應用程序部署到一個不同locale的服務器,你不需要改變代碼,Locale會自動調整。
    3.        <base>標簽:表示所包含頁面的絕對位置。這個標簽只有內嵌在head標簽中才有效。
    <html:base/>

    此行代碼解析后:
    <base href=\"http://www.mymain.com/myStrutsApp/testing.jsp\">
    4.        <img>標簽
    最重要的屬性page:圖象文件的路徑,前面必須帶有一個斜線。
    其它屬性:heigntwidthalt
       <html:img page=\"/logo.gif\" height=\"50\" width=\"200\" alt=\"Web Logo\"/>
    5.        <link>標簽
    <html:link page=\"/index.html\">Click demo</html:link>

    此行代碼解析后:
       <a href=\"/index.html\">Click demo</a>
    6.        <errors>標簽:通過一個簡單的<html:errors/>標簽,你就可以在一個JSP頁面上顯示完全自定義的錯誤信息。功能超強大!!
    說明:這個標簽在Request對象的屬性集合中查找reserved key。如果它找到一個reserved key,它就假設這個key是一個String、或是一個String數組  
         
    (它包含在模塊的MessageResources中查找的message keys)、或是類型為org.apache.struts.action.ActionErrors的一個對象。
            
    如果在應用程序資源中存在相應的信息,那么就可以用下面這些可選的message keys  
            · errors.header   or errors.prefix
    :相應的信息在錯誤信息的單獨列表前顯示。
            · errors.footer or errors.suffix
    :相應的信息在錯誤信息的單獨列表后顯示。
    7.        <form>標簽系列
    使用<form>標簽時必須遵循一些規則:
    1.       標簽中必須包含一個action屬性,它是這個標簽中唯一必需的屬性。如果不具備該屬性則JSP頁面會拋出一個異常。之后你必須給這個action屬性指定一個有效值。一個有效值是指應用程序的Struts配置文件中元素里的任何一個子元素的訪問路徑。而且相應的元素中必須有一個name屬性,它的值是form bean的名稱。
    <html:form action=\"/login\" >

    如果你有上述一個標簽 ,那么你的Struts配置文件的元素中必須有一個如下顯示為粗體的元素:
    <action-mappings>
          <action path=\"/login\"
           type=\"com.javapro.struts.LoginAction\"  
           name=\"loginForm\"
           scope=\"request\"
           input=\"/login.jsp\">
           <forward name=\"success\" path=\"/mainMenu.jsp\"/>
         </action>
         .
         .
         .
    </action-mappings> //
    這就是說一個form標簽是和form bean相關聯的。
    2.      
    3.       任何包含在<form>中用來接收用戶輸入的標簽(<text><password><hidden><textarea><radio><checkbox><select>)必須在相關的form bean中有一個指定的屬性值。比如,如果你有一個屬性值被指定為“username”<text>標簽,那么相關的form bean中也必須有一個名為“username”的屬性。輸入<text>標簽中的值會被用于生成form beanuserName屬性。

    <form>
    標簽還有一些不是必須但很有用的次要屬性。
    比如,你可以用focus屬性來生成JavaScript,它會定焦focus)到該form所包含的一個元素上。使用focus屬性時你需要給它指定元素的名稱。
    <body>
    <html:form action=\"/login\" focus=\"password\">
    User Name: <html:text property=\"userName\"/>
    <br>Password: <html:text property=\"password\"/>
    <br><html:submit/>
    </html:form>
    </body>

    代碼解析后:
    <body>
    <form name=\"loginForm\" method=\"post\" action=\"/myStrutsApp/login.do\">
    User Name: <input type=\"text\" name=\"userName\" value=\"\">
    <br>Password: <input type=\"text\" name=\"password\" value=\"\">
    <br><input type=\"submit\" value=\"Submit\">
    </form>
    <script language=\"JavaScript\" type=\"text/javascript\">
       <!--
    if (document.forms[\"loginForm\"].elements[\"password\"].type != \"hidden\")
           document.forms[\"loginForm\"].elements[\"password\"].focus()
       // -->
    </script>

    </body>
    有沒有看到這個標簽庫是如何建立JavaScript來定焦到password元素上的? 這也是該庫讓人著迷的地方之一。你不用擔心如何在客戶端進行編程,它會幫你自動生成。
    還可以看到,<form>標簽中method屬性的缺省值是POST

    <text>
    標簽、<hidden>標簽、<textarea>標簽、<radio>標簽、<checkbox>標簽、<submit>標簽、<reset>標簽:
    都有一個property屬性,最后會被轉換成HTML中的name屬性,當然還有namevalue屬性。

    <password>
    標簽
       <html:password property=\"password\"   redisplay=\"false\"/>
    該標簽中的一個很重要的屬性是"redisplay",它用于重新顯示以前輸入到這個區域中的值。該屬性的缺省值為true。然而,為了使password不能被重新顯示,你或許希望將該屬性的值設為false

    <select>
    標簽和<option>標簽:
    <html:select property=\"color\" size=\"3\">
       <html:option value=\"r\">red</html:option>
       <html:option value= \"g\">green</html:option>
       <html:option value= \"b\">blue</html:option>
    </html:select>

    posted on 2009-02-15 17:29 丁克設計 閱讀(189) 評論(0)  編輯  收藏 所屬分類: struts標簽


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導航

    留言簿(6)

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    主站蜘蛛池模板: 亚洲AV永久纯肉无码精品动漫| 五级黄18以上免费看| 久久久久久久99精品免费| 亚洲毛片av日韩av无码| 国产精品免费一区二区三区 | 亚洲欧洲日本精品| 在线亚洲精品视频| 免费观看午夜在线欧差毛片| 亚洲av永久中文无码精品综合| 国产精品99精品久久免费| 亚洲Av无码专区国产乱码DVD| 亚洲a∨无码一区二区| 国产美女无遮挡免费网站| 国产亚洲成在线播放va| 日韩免费精品视频| 亚洲精品无码久久久久APP | 亚洲中文字幕日产乱码高清app| 美女视频黄免费亚洲| 久久精品成人免费观看| 亚洲精品午夜视频| 四虎影视大全免费入口| 羞羞视频免费网站日本| 亚洲爆乳无码专区| 成人免费福利电影| 国产精品亚洲自在线播放页码| 久久国产乱子伦精品免费一| 亚洲欧洲日产国码二区首页 | 亚洲国产精品无码久久久蜜芽 | 亚洲精华国产精华精华液好用| 国产人成免费视频网站| 欧美亚洲精品一区二区| 青春禁区视频在线观看直播免费| 亚洲欧洲在线观看| 国产精品四虎在线观看免费| 成人毛片100免费观看| 亚洲国产日韩在线成人蜜芽 | 国产精品极品美女免费观看| 最新久久免费视频| 国产成人亚洲综合无码精品 | 2022久久国产精品免费热麻豆| 亚洲AV一宅男色影视|