js怎么能取得多选下拉框选中的多个值?

<selectname="i_ts_desc"id="i_ts_desc"multiple="true"><optionvalue="1">A</option><opti... <select name="i_ts_desc" id="i_ts_desc" multiple="true">
<option value="1">A</option>
<option value="2">B</option>
<option value="3">C</option>
<option value="4">D</option>
</select>
选中前两项,如何用js将选中的选项存成数组,传值到action中,希望哪位大侠将实现代码告知。我是这样在js中取得,然后ajax局部刷新把值传到action中,我选三个,但是只能取到一个值。注意:1,2,3和A,B,C的值都要取得。
var desc_id=[];
var desc=[];
desc_id = document.all("i_ts_desc").value;
desc = document.all("i_ts_desc").options[document.all("i_ts_desc").selectedIndex].text;
展开
 我来答
learneroner
高粉答主

推荐于2017-10-09 · 关注我不会让你失望
知道大有可为答主
回答量:1.1万
采纳率:91%
帮助的人:5839万
展开全部

方法:获取多选下拉框对象数组→循环判断option选项的selected属性(true为选中,false为未选中)→使用value属性取出选中项的值。实例演示如下:

1、HTML结构

<select id="test" multiple="true">
<option value="option-A">option-A</option>  
<option value="option-B">option-B</option>
<option value="option-C">option-C</option> 
<option value="option-D">option-D</option>
</select>
<input type="button" value="确定" onclick="fun()" />

2、javascript代码

function fun(){
var select = document.getElementById("test");
var str = [];
for(i=0;i<select.length;i++){
if(select.options[i].selected){
str.push(select[i].value);
}
}
alert(str);
}

3、效果演示

ThinkIBM
推荐于2018-12-20 · TA获得超过5288个赞
知道大有可为答主
回答量:3263
采纳率:0%
帮助的人:5296万
展开全部
var desc_id=[];
var obj = document.getElementById("i_ts_desc");
for(var i=0;i<obj.options.length;i++){
if(obj.options[i].selected){
desc_id.push(obj.options[i].value);// 收集选中项
}
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
stenger
2011-01-25 · TA获得超过726个赞
知道小有建树答主
回答量:1577
采纳率:0%
帮助的人:1342万
展开全部
下拉框中一次只能获取一个值呀,你可以这样实现:
1 你每次选择一次select 把onchange触发时候的值存到一个input中
这样你多次选择select之后 input中就有多个值了
2 你再把整个input值ajax发送出去
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
流香羽
2011-01-25 · TA获得超过1540个赞
知道小有建树答主
回答量:925
采纳率:50%
帮助的人:1307万
展开全部
我之前回答过您的下拉框的一个问题,如果您经常做一些前端交互工作,您可以学习一下jQuery,非常强大和有名的JS类库,可以简单的帮您实现。
例如您想实现一个AJAX效果:
$.ajax({
type:"POST", //数据传送方法
url:"test/", //ajax提交地址
data:$("form").serialize(), //直接将表单值转换成字符串
success: function () {} //成功后处理函数
});
是不是很简洁,而且使用jQuery获得表单的值也是非常简单的,你可以下载jQuery API学习一下,他们官网看参考资料。
jQuery同时还有个form插件,可以直接帮你以ajax方式提交数据库的。

参考资料: http://jquery.com/

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2011-01-25
展开全部
直接用:
Request("i_ts_desc")试下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式