国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

學習Struts提供的和Form相關的標簽

2019-11-18 12:55:26
字體:
來源:轉載
供稿:網友

  在本文系列的第一部分中我講述了如何使用Struts提供的Html標簽庫來配置一個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.java     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>Pass
Word: <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>
  
  在本文系列的第二部分,你學到了一些更重要的和form相關的標簽。在使用這些標簽之前,你必須依照一些規則以便正確地運用它們。第三部分將講述如何在真正的程序中使用這些標簽。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 天台县| 彭阳县| 英超| 台南市| 常熟市| 垦利县| 韩城市| 青川县| 肇东市| 辽阳县| 志丹县| 甘德县| 大化| 庄浪县| 乡城县| 惠州市| 响水县| 翼城县| 庆安县| 剑河县| 保亭| 吉水县| 武威市| 永胜县| 获嘉县| 化隆| 即墨市| 双流县| 昌图县| 鞍山市| 昌邑市| 安徽省| 泸西县| 台山市| 绥滨县| 东辽县| 张家界市| 海阳市| 水富县| 丹东市| 临沭县|