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"
這相當于進行下面的調用:
getFoo().getBar().getBaz();
或者做為setter:
getFoo().getBar().setBaz(value);
|
雖然Struts 標簽的設計原意是為了避免使用scriptlet,scriptlet的表達式還能夠提供給所有的Struts 標簽使用。但請確保使用完整的表達式:
錯誤:
<html:link href="'<%= "/" + name %>/index.jsp>'>
正確:
<html:link href="'<%= "/" + name + "/index.jsp" %>'> // 表達式必須提供整個屬性值
|
Html 標簽庫
1. <html>標簽
它有兩個屬性:locale和xhtml,兩者都不是必需的。
<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:圖象文件的路徑,前面必須帶有一個斜線。
其它屬性: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>
此行代碼解析后:
<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 bean的userName屬性。
<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屬性,當然還有name和value屬性。
<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>
|