form 標簽的列表是Struts的UI標簽的一個子集。這些標簽可以幫助渲染中需要Struts Web應用程序和用戶界面可以分為三類。本章將帶你通過所有三種類型的UI標簽:
我們已經(jīng)使用這些標簽已經(jīng)在我們的例子中。讓我們來看看一個簡單的一些簡單UI標簽的視圖頁面email.jsp:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%> <%@ taglib prefix="s" uri="/struts-tags"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <s:head/> <title>Hello World</title> </head> <body> <s:div>Email Form</s:div> <s:text name="Please fill in the form below:" /> <s:form action="hello" method="post" enctype="multipart/form-data"> <s:hidden name="secret" value="abracadabra"/> <s:textfield key="email.from" name="from" /> <s:password key="email.password" name="password" /> <s:textfield key="email.to" name="to" /> <s:textfield key="email.subject" name="subject" /> <s:textarea key="email.body" name="email.body" /> <s:label for="attachment" value="Attachment"/> <s:file name="attachment" accept="text/html,text/plain" /> <s:token /> <s:submit key="submit" /> </s:form> </body> </html>
如果你是知道的HTML,那么所有使用的標簽是很常見的HTML標簽與一個額外前綴s:隨著每個標簽和不同的屬性。當我們執(zhí)行上面的程序中,我們可以得到以下的用戶界面,只要使用所有鍵設置正確的映射。
如圖所示,s:head產(chǎn)生Struts2的應用程序所需的javascript和樣式表元素。
接下來,我們有s:div和s:text元素。s:div被用來渲染HTML DIV元素。這是非常有用的當混合使用HTML和Struts標簽。對于這些人來說,他們有選擇使用s:div來呈現(xiàn)一個div。
s:text如圖所示用于在屏幕上呈現(xiàn)文本。
接下來我們有s:form標簽。 s:form標簽決定提交表單的action屬性。因為我們有一個文件上傳元素的形式,我們必須設置enctype屬性multipart。否則,我們就可以保留此空白。
在表單標簽的末尾,我們有s:submit標簽。這是用來提交表單。當提交表單時,所有的表單值提交到指定的動作在s:form標簽。
s:form里面,我們有一個隱藏的屬性稱為secret。這使得一個隱藏的元素在HTML中。在我們的案例中,“秘密”的元素值“abracadabra”。此元素向最終用戶是不可見的,并用于承載的狀態(tài)下,從一個視圖。
接下來,我們有s:label, s:textfield, s:password 和 s:textarea標簽。這些用于呈現(xiàn)標簽,輸入字段,密碼和文本區(qū)域分別。我們所看到的這些動作“Struts - 發(fā)送電子郵件”例子。這里要注意的最重要的事情是使用“key”屬性。 “key”屬性用于獲取這些控件從屬性文件中的標簽。
然后,我們有 s:file標記使得輸入文件上傳組件。該組件允許用戶上傳文件。在這個例子中,我們使用了“accept” 參數(shù)位置s:file 指定允許上傳的文件類型的文件標記。
最后,我們有s:token 標簽。令牌的標簽,這是用來找出雙提交表單是否已經(jīng)生成一個獨特的標記。
表單呈現(xiàn)時,一個隱藏的變量被放置令牌值。讓我們說,例如令牌是“ABC”。當表單提交時,Struts過濾器會檢查對存儲在會話的令牌令牌。如果匹配,它消除了從會話令牌?,F(xiàn)在,如果意外形式(無論是通過刷新或通過點擊瀏覽器的后退按鈕)重新提交,表單將被重新提交“ABC”作為標記。在這種情況下,過濾器將檢查對再次存儲在會話中的令牌的令牌。但由于令牌“ABC”已經(jīng)從會話中刪除,這將不匹配和Struts的過濾器將拒絕請求。
組UI標簽被用來創(chuàng)建單選按鈕,復選框。讓我們來看看一個簡單的視圖頁的helloWorld.jsp的復選框和單選按鈕標簽:
<%@ page contentType="text/html; charset=UTF-8"%> <%@ taglib prefix="s" uri="/struts-tags"%> <html> <head> <title>Hello World</title> <s:head /> </head> <body> <s:form action="hello.action"> <s:radio label="Gender" name="gender" list="{'male','female'}" /> <s:checkboxlist label="Hobbies" name="hobbies" list="{'sports','tv','shopping'}" /> </s:form> </body> </html>
當我們執(zhí)行上述程序的輸出將看起來類似于以下內(nèi)容:
現(xiàn)在讓我們來看看這個例子。在第一個例子中,我們創(chuàng)建了一個簡單的單選按鈕,“Gender”的標簽。單選按鈕標簽的name屬性是強制性的,所以我們指定一個名稱是“Gender”。然后我們提供一個列表的性別。這份名單是填充值“male”和“female”。因此,在輸出中,我們得到了一個單選按鈕,其具有兩個值。
在第二個例子中,我們創(chuàng)建了一個復選框列表。這是收集用戶的愛好。用戶可以有一個以上的愛好,因此,我們所使用的復選框,而不是單選按鈕。該復選框被填充列表"sports", "Tv" 和 "Shopping"。這就提出了一個復選框列表的愛好。
讓我們來探討Struts提供的選擇標記的不同變化。讓我們來看看一個簡單的視圖頁的helloWorld.jsp的select標簽:
<%@ page contentType="text/html; charset=UTF-8"%> <%@ taglib prefix="s" uri="/struts-tags"%> <html> <head> <title>Hello World</title> <s:head /> </head> <body> <s:form action="login.action"> <s:select name="username" label="Username" list="{'Mike','John','Smith'}" /> <s:select label="Company Office" name="mySelection" value="%{'America'}" list="%{#{'America':'America'}}"> <s:optgroup label="Asia" list="%{#{'India':'India','China':'China'}}" /> <s:optgroup label="Europe" list="%{#{'UK':'UK','Sweden':'Sweden','Italy':'Italy'}}" /> </s:select> <s:combobox label上一篇:Struts2教程下一篇:<s:a>標簽示例