下面是幾個Struts2的例子來說明如何通過List, OGNL 和物件生成一個無線電鈕預設值(預先選擇)。
在Java程式碼中建立一個列表返回無線電鈕的值。
//... List<String> genders = new ArrayList<String>(); genders.add("male"); genders.add("female"); genders.add("unknown"); //... public List<String> getGenders() { return genders; } public String getDefaultGenderValue(){ return "unknown"; } //...
在結果頁面中,<s:radio>標籤, list=」genders」將呼叫 getGenders()方法返回列表無線電鈕的鍵和值。以及 value=」defaultGenderValue」 會呼叫 getDefaultGenderValue() 方法來 預先選擇「unknown」值作為無線電鈕的預設值。
<s:radio label="Gender" name="yourGender" list="genders" value="defaultGenderValue" />
它會生成以下HTML程式碼...
<input type="radio" name="yourGender" id="resultAction_yourGendermale" value="male"/> <label for="resultAction_yourGendermale">male</label> <input type="radio" name="yourGender" id="resultAction_yourGenderfemale" value="female"/> <label for="resultAction_yourGenderfemale">female</label> <input type="radio" name="yourGender" id="resultAction_yourGenderunknown" checked="checked" value="unknown"/> <label for="resultAction_yourGenderunknown">unknown</label>
在結果頁面中,通過建立OGNL表示式無線電鈕,並預先選擇「2」為預設值。
<s:radio label="Answer" name="yourAnswer" list="#{'1':'Yes','2':'No'}" value="2" />
它會生成以下HTML程式碼...
<input type="radio" name="yourAnswer" id="resultAction_yourAnswer1" value="1"/> <label for="resultAction_yourAnswer1">Yes</label> <input type="radio" name="yourAnswer" id="resultAction_yourAnswer2" checked="checked" value="2"/> <label for="resultAction_yourAnswer2">No</label>
在Java程式碼中,建立語言物件languageCode和languageDisplay的屬性。
//... public class Language{ private String languageCode; private String languageDisplay; //getter and setter methods }
//... List<Language> languages = new ArrayList<Language>(); languages.add( new Language("EN", "English") ); languages.add( new Language("FR", "France") ); languages.add( new Language("CN_ZH", "Chinese") ); languages.add( new Language("DE", "German") ); //... public List<Language> getLanguages() { return languages; } public String getDefaultLanguageValue(){ return "CN_ZH"; } //...
在結果頁面中,<s:radio> 標籤,list=」languages」 會呼叫 getLanguages()方法返回無線電鈕鍵和值的列表。 listKey=」languageCode」 表示語言的 languageCode屬性為無線電鈕的鍵; listValue=」languageDisplay」 表示語言的languageDisplay屬性為無線電鈕的值。最後 value=」defaultLanguageValue」 會呼叫 getDefaultLanguageValue() 方法預先選擇「CN_ZH」 作為無線電鈕的預設值。
<s:radio label="Gender" name="yourLanguage" list="languages" listKey="languageCode" listValue="languageDisplay" value="defaultLanguageValue" />
它會生成以下HTML程式碼...
<input type="radio" name="yourLanguage" id="resultAction_yourLanguageEN" value="EN"/> <label for="resultAction_yourLanguageEN">English</label> <input type="radio" name="yourLanguage" id="resultAction_yourLanguageFR" value="FR"/> <label for="resultAction_yourLanguageFR">France</label> <input type="radio" name="yourLanguage" id="resultAction_yourLanguageCN_ZH" checked="checked" value="CN_ZH"/> <label for="resultAction_yourLanguageCN_ZH">Chinese</label> <input type="radio" name="yourLanguage" id="resultAction_yourLanguageDE" value="DE"/> <label for="resultAction_yourLanguageDE">German</label>