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

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

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

    posts - 0,comments - 0,trackbacks - 0

    在本文中我講述了如何使用Struts提供的form相關的標簽。

     

    與form相關的標簽包括<form>標簽本身以及所有必須包含在其中的標簽。比如,<text>和<password>標簽就是和form相關的標簽,因為如果不把它們放到一個form中它們就沒有意義。

     

    <form>標簽
    <form>標簽用于生成一個HTML form。使用該標簽時必須遵循許多規則。

     

    首先,<form>標簽中必須包含一個action屬性,它是這個標簽中唯一必需的屬性。如果不具備該屬性則JSP頁面會拋出一個異常。之后你必須給這個action屬性指定一個有效值。一個有效值是指應用程序的Struts配置文件中<action-mappings>元素里的任何一個<action>子元素的訪問路徑。而且相應的<action>元素中必須有一個name屬性,它的值是form bean的名稱。

     

    例如,如果你有這樣一個<form>標簽:   <html:form action="/login" >

     

    那么你的Struts配置文件的<action-mappings>元素中必須有一個如下顯示為粗體的<action>元素:
      <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相關聯的。

     

    另一個要遵循的規則是:任何包含在<form>中用來接收用戶輸入的標簽(<text>、<password>、<hidden>、<textarea>、<radio>、<checkbox>、<select>)必須在相關的form bean中有一個指定的屬性值。比如,如果你有一個屬性值被指定為“username”的<text>標簽,那么相關的form bean中也必須有一個名為“username”的屬性。輸入<text>標簽中的值會被用于生成form bean的userName屬性。

     

    除了上面所講的屬性之外,<form>標簽還有一些不是必須但加上更好的“次要”的屬性。比如,你可以用focus屬性來生成JavaScript,它會“定焦”(focus)到該form所包含的一個元素上。使用focus屬性時你需要給它指定元素的名稱。比如,以下代碼是定焦在第二個Text元素上的: <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="/myStrutsApp6/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>
    注意,<form>標簽中method屬性的缺省值是POST。另外,有沒有看到這個標簽庫是如何建立JavaScript來定焦到password元素上的? 這也是該庫讓人著迷的地方之一。你不用擔心如何在客戶端進行編程,它會幫你自動生成。

     

    在運行前面的例子時還要注意,你必須有一個包含userName和password屬性的相關form。你可以參考本文第三部分中的Login程序。

     

    <text>標簽
    <text>標簽用于生成一個文本的輸入區域。它必須包含和相關form bean中的相同屬性對應的“property”屬性。該標簽只有在嵌入到一個<form>標簽中時才有效。
    例如: <html:text property="userName"/>
    會被轉換成: <input type="text" name="userName" value="">

     

    <password>標簽
    <password>標簽用于生成一個口令字(type password)的輸入區域。它必須包含和相關form bean中的相同屬性對應的“property”屬性。該標簽只有在嵌入到一個<form>標簽中時才有效。該標簽中的一個很重要的屬性是“redisplay”,它用于重新顯示以前輸入到這個區域中的值。該屬性的缺省值為true。然而,為了使password不能被重新顯示,你或許希望將該屬性的值設為false。
    例如: <html:password property="password" redisplay="false"/>
    會被轉換成: <input type="password" name="password" value="">

     

    <hidden>標簽
    <hidden>標簽用于生成一個隱藏文本的輸入區域。它必須包含和相關form bean中的相同屬性對應的“property”屬性。該標簽只有在嵌入到一個<form>標簽中時才有效:
    例如: <html:hidden property="userName"/>
    會被轉換成: <input type="hidden" name="userName" value="">

     

    <textarea>標簽
    <textarea>標簽用于生成一個文本區元素(text area element)。它必須包含和相關form bean中的相同屬性對應的“property”屬性。

     

    比如:
    <html:textarea property="details" cols="80" rows="20" value="Enter details here"/>
    會被轉換成:
    <textarea name="details" cols="80" rows="20">Enter details here</textarea>

     

    <radio>標簽
    <radio>標簽用于顯示一個單選按鈕(radio button)。它必須包含“value”屬性。比如這段代碼: <html:radio property="title" value="1"/>Mr.
    <html:radio property="title" value="2"/>Ms.
    <html:radio property="title" value="3"/>Dr.
    會被轉換成這樣的HTML:
    <input type="radio" name="title" value="1">Mr.
    <input type="radio" name="title" value="2">Ms.
    <input type="radio" name="title" value="3">Dr.

     

    <checkbox>標簽
    <checkbox>標簽用于顯示checkbox類型的輸入區域。比如:
    <html:checkbox property="notify"/>Please send me notification
    會被轉換成:
    <input type="checkbox" name="notify" value="on">Please send me notification

     

    <submit>標簽
    <submit>標簽用于生成提交類型(type submit)的輸入區域。
    比如: <html:submit value="Login"/>
    會被轉換成: <input type="submit" value="Login">
     

     


    <reset>標簽
    <reset>標簽用于生成重置類型(type reset)的輸入區域。比如:
    <html:reset/>
    會被轉換成: <input type="reset" value="Reset">

     

    <option>標簽
    <option>標簽用于顯示select box中的一個選項。參照下面的<select>標簽。

     

    <select>標簽
    <select>標簽用于顯示一個包含零個或更多選項的HTML選擇元素。它必須被嵌入一個<form>標簽中才有效。下面這個例子將說明如何使用該標簽: <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>

     

    會被轉換成:
    <select name="color" size="3"><option
          value="r">red</option>
      <option value="g">green</option>
      <option value="b">blue</option>
    </select>
     

    posted on 2006-01-13 22:01 VictorWu 閱讀(143) 評論(0)  編輯  收藏 所屬分類: JavaWeb框架

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


    網站導航:
     
    主站蜘蛛池模板: 污网站免费在线观看| ww亚洲ww在线观看国产| 一级毛片aaaaaa视频免费看| 国产美女无遮挡免费网站| 亚洲精品国产首次亮相| 国产色婷婷精品免费视频| 九九精品国产亚洲AV日韩| 日韩在线免费电影| 伊人久久国产免费观看视频| 亚洲综合色婷婷七月丁香| 最近免费mv在线观看动漫| 亚洲精品无码久久久久久久| 99视频全部免费精品全部四虎| 亚洲精品中文字幕无乱码| 在线观看免费高清视频| 亚洲AV成人精品一区二区三区| 亚洲VA综合VA国产产VA中| 中文字幕在线观看免费| 精品亚洲A∨无码一区二区三区| 91网站免费观看| 国产精品亚洲精品爽爽| 亚洲免费人成在线视频观看| 最近2019年免费中文字幕高清 | 色屁屁www影院免费观看视频| 亚洲美女高清一区二区三区| 精品免费tv久久久久久久| 亚洲videos| 中文字幕亚洲无线码a| 222www免费视频| 色屁屁在线观看视频免费| 亚洲男人的天堂在线播放| 97在线线免费观看视频在线观看| 美国免费高清一级毛片| 亚洲成色999久久网站| 韩国18福利视频免费观看| 99在线免费观看| 亚洲精品亚洲人成在线| 亚洲国产精品无码专区| 最新猫咪www免费人成| 日本高清免费观看| 美女扒开尿口给男人爽免费视频 |