在开发中我们常用到struts2的form表单组件,其中select最常用的写法如下:
<s:select label="对象类型" name="emp.deptId" list="listValues" listKey="oid" listValue="name" headerKey="" headerValue="--请选择--" onchange="changeHidenValue(this)"></s:select>
当提交表单时,只能在后台获得listKey的值,而无法提交listValue的值。
现有需求同时提交listKey和listValue,解决方法如下:
1、在select的onchange事件函数中,获得option中的text,即listValue。
2、这时,写回到表单的一个隐藏域中。
首先,在<s:select>标签中添加 (onchange="changeHidenValue(this)")。然后在表单中添加隐藏域<input type=hidden id="deptName" name="emp.deptName" value=""/>。最后写事件绑定函数,如下:
function changeHidenValue(elem){
var optionVal= $(elem).find("option:selected").text(); // 取到选中的listValue(Option)的值
$("#deptName").val(optionVal);
}
点击表单提交测试一下,结果正确!
==================struts2 s:select 标签=============
1 静态生成
- <s:select name="user.sex" list="#{'0':'男','1':'女'}" label="性别" headerKey="" headerValue="请选择性别"></s:select>
注解:这里从页面来静态(也就是在页面中写死啦)构造下拉选项,关键点是list="#{'0':'男','1':'女'}" 通过它实现的select的两个option 。headerKey指定缺省的选项"key",headerValue指定缺省的选项"value"。
2.设置下拉框数据源
- <%
- java.util.HashMap map = new java.util.LinkedHashMap();
- map.put(1, "aaa");
- map.put(2, "bbb");
- map.put(3, "ccc");
- request.setAttribute("map", map);
- request.setAttribute("aa", "2");
- %>
- <s:select list="#request.map" label="abc" listKey="key" listValue="value" value="#request.aa" headerKey="0" headerValue="aabb">
- </s:select>
value的值设置为了2,所以初始化下拉框时,会自动选择key值为2的选项
3.action传递list过来
- public class Program implements Serializable {
- /** serialVersionUID */
- private static final long serialVersionUID = 1L;
- private int programid;
- private String programName;
- public int getProgramid() {
- return programid;
- }
- public void setProgramid(int programid) {
- this.programid = programid;
- }
- public String getProgramName() {
- return programName;
- }
- public void setProgramName(String programName) {
- this.programName = programName;
- }
- }
action
- xxxAction extends extends ActionSupport {
- private List<Program> programs ;//list集合
- public List<Program> getPrograms() {
- return programs;
- }
- public void setPrograms(List<Program> programs) {
- this.programs = programs;
- }
- }
jsp页面
- <s:select list="programs " listValue="programName " listKey="programid " name="program" id="program"
- headerKey="0l" headerValue="" >
- </s:select>
listKey说明下拉框的key值对应 programid字段,listValue说明下拉框的显示部分对应programName字段
相关推荐
<s:select list="#{1:'aa',2:'bb',3:'cc'}" label="abc" listKey="key" listValue="value" headerKey="0" headerValue="aabb"> ``` 这个例子中,`list`属性是用哈希映射表示的,键值对分别为1对应'aa',2对应'bb',3...
<s:select name="fieldName" list="listName" listKey="keyField" listValue="valueField" /> ``` - `name`:该属性指定输入字段的名称,对应于Action类中的属性。 - `list`:此属性用于指定选项的数据源,可以...
例如:<s:select name="favouriteLanguage" list="favouriteLanguages" listKey="key" listValue="description" />,该标签将生成一个名为“favouriteLanguage”的动态列表框控件,并从Action中获取列表数据。...
<s:select list="countries" listKey="code" listValue="name" label="国家" name="selectedCountry"/> ``` 这里的`list`属性指定了列表数据源,`listKey`和`listValue`分别指定了列表项的键和值,`name`属性则用于...
例如,`<s:select list="countries" listKey="code" listValue="name" name="selectedCountry"/>`将根据"countries"属性创建一个下拉列表,其中"code"作为键,"name"作为显示值。 5. `<s:textfield>`和`<s:textarea...
4. **`<s:select>`**:这个标签创建一个下拉列表,例如: ```jsp <s:select name="传递参数名" id="取值用的 id" list="#session.hlist" onchange="项改变事件" listKey="id" listValue="title" headerKey=...
7. **Struts2下拉菜单**:`<s:select>`标签用于创建下拉列表,通过`name`属性指定字段名,`list`属性提供选项的集合,`listKey`和`listValue`分别指定选项的键和值,`theme`用于设定样式,`headerKey`和`headerValue...
<s:select list="options" listKey="key" listValue="value" name="selectedOption" /> ``` `list`属性指定选项列表,`listKey`和`listValue`分别对应列表项的键和值,`name`属性用于指定表单字段名。 4. **表单...
通过实验,学员能够掌握Struts2中几个常用标签(如`<s:radio>`、`<s:select>`、`<s:token>`)的应用,并理解OGNL表达式的基本用法。这些知识点对于初学者来说至关重要,因为它们构成了Struts2应用开发的基础。 ####...
<s:select list="maptest" listKey="id" listValue="name"></s:select> ``` 这里的`list`属性指定了`maptest`列表作为数据源,`listKey`属性用于指定从`Map`对象中获取选项的值(option的value),而`listValue`...
List<SelectOption> options = new ArrayList<>(); try { transaction = session.beginTransaction(); // 假设我们有一个名为Option的实体类,对应数据库中的option表 List<Option> dbOptions = session....
创建下拉菜单使用`s:select`标签,如`<s:select name="ct_sid" list="ctypesonlist" listKey="ct_id" listValue="ct_name" theme="simple" headerKey="0" headerValue="一级栏目">`. `list`属性指定列表的源,`...
这里的`<s:select>`标签是Struts2框架提供的,用于生成HTML select元素。`list`属性指定的是后台传入的列表数据,`onchange`事件触发时会调用`getTsFromDescribe`函数,实现二级菜单的动态加载。 在后台,我们通常...
<s:select list="sexList" listKey="key" listValue="value" headerKey="" headerValue="--请选择--" /> ``` 在这种情况下,Action类需要包含一个名为`sexList`的Map属性,Map的键值对将对应于下拉框的值和显示文本...
<s:select name="selectedOption" list="optionsMap" listKey="key" listValue="value" /> ``` 这样,下拉列表的选项将会显示Map的值,而选中的值(提交到服务器时)将是对应的键。 ### 结论 Struts2的`select`...
<s:select name="selectedOption" list="options" listKey="id" listValue="name" /> ``` 在这个例子中,`MyEntityService`使用Hibernate查询数据库并返回一个包含所有实体的列表。Action执行后,这个列表会被注入...
<s:select list="#request.map" label="abc" listKey="key" listValue="value" value="#request.aa" headerKey="0" headerValue="aabb"/> ``` 这个例子从请求作用域获取`Map`数据,并根据`value`属性设置默认选中...
Map<String, String> genders = new HashMap<>(); genders.put("M", "男"); genders.put("F", "女"); ``` 然后在JSP页面中,我们可以这样使用`radio`标签: ```jsp <s:radio name="user.gender" list="genders" /> `...
<s:checkboxlist name="beans" list="#request.persons" listKey="id" listValue="name" /> ``` 这将根据请求中`persons`属性的列表创建复选框,显示`id`作为值,`name`作为标签。 ### 2. 表单标签Radio - 单选...