Action控制select控件的内容(1.struts方法;2.js方法)

1.struts2标签法:
参考文档:
请参考下面代码:
<s:select list="#{1:'第一项',2:'第二项'}" listKey="key" listValue="value" value="2" />
该代码运行结果:默认显示的是“第二项”


truts2的select标签中,常用的有以下几个属性:
(1)struts2中的select 标签中,必须设置的属性只有一个,即是list。
(2)select 标签的list中必须有值,不然会报错。如果没有值,可以加上headerKey, headerValue,这样就可以通过了。即使list中有值,我们也通常会加上headerKey, headerValue,即列表中显示的第一个选项。注意,headerKey不可以为空,不可以为-1。
(3)list属性:通常是在 action中定义的,必须是一个可以迭代的源,如为一个List, Map, Set等。如果是一个Map,那么map的key就对应于select标签中的value,map中的value就对应于select标签中的 option。而如果是一个List或者是一个Set,那么可以通过listKey和listValue指定。
(4)listKey和 listValue:listKey即对应于select标签中的value, listValue即对应于select标签中的option。
(5)name属性:即是表单中select的名称。


实例:在action中初始化好alarmReasonList之后,在页面中:
<td>
<s:select id="alarmReason" name="hPSPlateAlarm.alarmReason" list="alarmReasonList" listKey="id" listValue="customName" style="width:155px"></s:select>
</td>


2.js方法:拼成json串:

var url = "dataQuery!getGateAndLane.action";
Ext.Ajax.request({
url : url,
success : function(response) {
var jsonReturn = response.responseText;// 得到json字符串

var gateAndLane = eval(jsonReturn); //将串转化为对象的List形式
var gateHtml = "";
var laneHtml = "";
for ( var i = 0; i < gateAndLane[0].gate.length; i++) {
gateHtml += "<option value='" + gateAndLane[0].gate[i].id
+ "'>" + gateAndLane[0].gate[i].name + "</option>";
}
for ( var j = 0; j < gateAndLane[0].lane.length; j++) {
laneHtml += "<option value='" + gateAndLane[0].lane[j].id
+ "'>" + gateAndLane[0].lane[j].name + "</option>";
}
$("#gate" + k).html("");
$("#gate" + k).html(gateHtml);
$("#lane" + k).html("");
$("#lane" + k).html(laneHtml);
},
failure : function(response) {
Ext.Msg.alert("失败", response.responseText);
}
});



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值