Struts提供了五個標籤庫,即:HTML、Bean、Logic、Template和Nested。
標籤庫 |
說明 |
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" |
雖然Struts 標籤的設計原意是爲了避免使用scriptlet,scriptlet的表達式還能夠提供給所有的Struts 標籤使用。但請確保使用完整的表達式:
錯誤: |
Html 標籤庫
1. <html>標籤
它有兩個屬性:locale和xhtml,兩者都不是必需的。
<html:html locale=/"true/"> |
2. 說明:生成的結果取決於Struts應用程序所位於的服務器的locale。如果你將應用程序部署到一個不同locale的服務器,你不需要改變代碼,Locale會自動調整。
3. <base>標籤:表示所包含頁面的絕對位置。這個標籤只有內嵌在head標籤中才有效。
<html:base/> |
4. <img>標籤
最重要的屬性page:圖象文件的路徑,前面必須帶有一個斜線。
其它屬性:heignt、width、alt。
<html:img page=/"/logo.gif/" height=/"50/" width=/"200/" alt=/"Web Logo/"/> |
5. <link>標籤
<html:link page=/"/index.html/">Click demo</html:link> |
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/" > |
2.
3. 任何包含在<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屬性時你需要給它指定元素的名稱。
<body> |
有沒有看到這個標籤庫是如何建立JavaScript來定焦到password元素上的? 這也是該庫讓人着迷的地方之一。你不用擔心如何在客戶端進行編程,它會幫你自動生成。
還可以看到,<form>標籤中method屬性的缺省值是POST。
<text>標籤、<hidden>標籤、<textarea>標籤、<radio>標籤、<checkbox>標籤、<submit>標籤、<reset>標籤:
都有一個property屬性,最後會被轉換成HTML中的name屬性,當然還有name和value屬性。
<password>標籤
<html:password property=/"password/" redisplay=/"false/"/> |
該標籤中的一個很重要的屬性是"redisplay",它用於重新顯示以前輸入到這個區域中的值。該屬性的缺省值爲true。然而,爲了使password不能被重新顯示,你或許希望將該屬性的值設爲false。
<select>標籤和<option>標籤:
<html:select property=/"color/" size=/"3/"> |
遺補:1.) <html:link>標籤
forward屬性:鏈接到一個global forward上;action屬性:鏈接到一個action mapping上;
href屬性:這個鏈接會轉發給控制器,由控制器做決定;page屬性:一個相對的鏈接。
用page屬性鏈接到action上:
<html:link page="/html-link.do"> |
注意,上面的代碼中你不必指定web的關聯。相反的,如果你使用href屬性,你就必須像下面所示指出web的關聯(這裏的關聯就是struts-exercise):
<html:link href="/struts-exercise-taglib/html-link.do"> |
很明顯,當你在相同的web應用程序中做鏈接是,它比page屬性更加好。你也能用href在不同的服務器上創建鏈接:
<html:link href="http://otherserver/strutsTut/html-link.do"> |
另一種鏈接到html-link.do的方法是用action屬性:
<html:link action="/html-link"> |
你也可以以硬編碼的方式使用參數:
<html:link page="/htmllink.do?doubleProp=3.3&longProp=32"> |
或者使用paramId, paramName, and paramProperty屬性:
<html:link page="/html-link.do" paramId="booleanProperty" paramName="testbean" |
解析後的代碼:
<a href="/struts-exercise-taglib/html-link.do?booleanProperty=false"> |
另外,還能使用帶name屬性的Map來實現傳遞多個參數:
<% |
你也能夠鏈接到Map類型的action上,上面的代碼解析後的結果:
<html:messages property="property2" message="true" id="msg" header="messages.header" footer="messages.footer"> |
2.) select和option標籤
<html:select> 的屬性:property-與ActionForm中的某個屬性對應;size-顯示option的數目;multiple-默認爲fales,表示不能多選,當設定爲true時,property對應的ActionForm的屬性必須爲數組。
<html:select property="name" size=6 multiple="true">
<html:option>的屬性:key、local、bundle-指定Resource Bundle中的內容。
例如 <html:option value="color1">Orange</html:option>
<html:option value="color1" bundle="htmlselect.Colors" key="htmlselect.red"/>
它和配置文件中的<message-resources>元素的key屬性匹配 --> <message-resource parmeter="HtmlSelectColors" key="htmlselect.Colors"/>
<message-resource>中配置的資源文件爲HtmlSelectColors.properties,相關內容爲 htmlselect.red=RED
<html:options>標籤,提供了一組<option>元素,在<html:select>元素中可以包含多個<html:options>元素。非常靈活,可以取得集合或數組中的值。
例1 <html:options collection="coll" property="value" labelProperty="label" /> 這指在coll的集合中存放了options,value指實際能被提交的值,label是顯示給用戶的值。
例2 <html:options property="value" labelProperty="label" /> collection屬性不被指定時,將使用表單相關的form bean,form bean中value屬性存放option value,label屬性值顯示給用戶。
例3 <html:options name="valueBean" property="values" labelName="labelsBean" labelProperty="labels" /> 這個意思是value值存放在名爲valueBean的bean的vlaues屬性中,它是一個collection;label值也是同樣的意思。
<html:optionsCollection>標籤,和<html:options>的用法很相似。
例如 <html:select property="custId"><html:optionsCollection property="customers" label="name" value="custId" /></html:select>
這個標籤和org.apache.structs.util.LabelValueBean結合的很好,如果把label和value都放到這個對象中,可以很簡單的這樣應用:
<html:select property="custId"><html:optionsCollection property="customers" /></html:select>