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; 展开
<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; 展开
6个回答
展开全部
方法:获取多选下拉框对象数组→循环判断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、效果演示
展开全部
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);// 收集选中项
}
}
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);// 收集选中项
}
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
下拉框中一次只能获取一个值呀,你可以这样实现:
1 你每次选择一次select 把onchange触发时候的值存到一个input中
这样你多次选择select之后 input中就有多个值了
2 你再把整个input值ajax发送出去
1 你每次选择一次select 把onchange触发时候的值存到一个input中
这样你多次选择select之后 input中就有多个值了
2 你再把整个input值ajax发送出去
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我之前回答过您的下拉框的一个问题,如果您经常做一些前端交互工作,您可以学习一下jQuery,非常强大和有名的JS类库,可以简单的帮您实现。
例如您想实现一个AJAX效果:
$.ajax({
type:"POST", //数据传送方法
url:"test/", //ajax提交地址
data:$("form").serialize(), //直接将表单值转换成字符串
success: function () {} //成功后处理函数
});
是不是很简洁,而且使用jQuery获得表单的值也是非常简单的,你可以下载jQuery API学习一下,他们官网看参考资料。
jQuery同时还有个form插件,可以直接帮你以ajax方式提交数据库的。
例如您想实现一个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")试下
Request("i_ts_desc")试下
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询