jQuery $.ajax传递数组的traditional参数传递必须true
2014-04-27 11:48
351 查看
起初我认为traditional:true,可有可无,但是后来不用traditional的时候,发现后台无法获取selectUsers的值,那么可以肯定的是traditional默认值是false.
当提交的参数是数组( {selectUsers:[value,value,value]} ),如果是false的话,则提交时会是"selectUsers[]=value&selectUsers[]=value"
如果设置成true,则提交时会是"selectUsers=value&selectUsers=value"
这样后台就能用String[] ids=request.getParameterValues("selectUsers"); 获取到值。
官方文档的解释如下:
traditional
类型:Boolean
如果你想要用传统的方式来序列化数据,那么就设置为 true。
Set this to true if you wish to use the traditional style of param serialization
一:前台jquery
deleteAll() {
var selectUsers=new Array();
//var selectUsers = null;
$(":checkbox[name='userID']").each(function() {
if ($(this).attr("checked"))
selectUsers.push($(this).val());
//selectUsers += "," + $(this).val();
})
//alert(selectUsers);
$.ajax({
//async : false,
traditional: true,
type:"post",
url:"elecUserAction_delete.do",
data:{selectUsers:selectUsers},
/* success:function(responsText){
if(responsText=="1"){
alert("删除成功");
}
} */
});
}
二:后台Action代码
public String delete(){
//ActionContext context=ActionContext.getContext();
//HttpServletRequest request=(HttpServletRequest)context.get(ServletActionContext.HTTP_REQUEST);
String[] ids=request.getParameterValues("selectUsers");
System.out.println(ids.toString());
PrintWriter out = null;
out.write("1");
return home();
}
当提交的参数是数组( {selectUsers:[value,value,value]} ),如果是false的话,则提交时会是"selectUsers[]=value&selectUsers[]=value"
如果设置成true,则提交时会是"selectUsers=value&selectUsers=value"
这样后台就能用String[] ids=request.getParameterValues("selectUsers"); 获取到值。
官方文档的解释如下:
traditional
类型:Boolean
如果你想要用传统的方式来序列化数据,那么就设置为 true。
Set this to true if you wish to use the traditional style of param serialization
一:前台jquery
deleteAll() {
var selectUsers=new Array();
//var selectUsers = null;
$(":checkbox[name='userID']").each(function() {
if ($(this).attr("checked"))
selectUsers.push($(this).val());
//selectUsers += "," + $(this).val();
})
//alert(selectUsers);
$.ajax({
//async : false,
traditional: true,
type:"post",
url:"elecUserAction_delete.do",
data:{selectUsers:selectUsers},
/* success:function(responsText){
if(responsText=="1"){
alert("删除成功");
}
} */
});
}
二:后台Action代码
public String delete(){
//ActionContext context=ActionContext.getContext();
//HttpServletRequest request=(HttpServletRequest)context.get(ServletActionContext.HTTP_REQUEST);
String[] ids=request.getParameterValues("selectUsers");
System.out.println(ids.toString());
PrintWriter out = null;
out.write("1");
return home();
}
相关文章推荐
- jquery获取URL参数
- 【jquery前端开发】可调整的幻灯片(图片轮播)
- jQuery常用遍历节点方法
- jquery实现复选框联动
- Dom对象和jQuery对象的相互转化
- Jquery实现仿淘宝天猫左侧分类导航插件
- jQuery基础与一些细节(2)
- 利用jQuery和CSS实现环形进度条
- window.onload 、body.onload 以及 jQuery 等dom加载完成后执行脚本的区别
- struts2+jQuery+ajax调用演示
- [jQuery1.9]Cannot read property ‘msie’ of undefined错误的解决方法
- SpringMVC:整合JQUERY与JSON
- 用el表达式显示jquery请求servlet数据的中文乱码问题
- 左右的移动<<>><>jQuery的实现
- [原]左右的移动<<>><>jQuery的实现
- jquery mobile如何实现滑动屏幕跳转页面
- jQuery基础与一些细节(1)
- jQuery学习之prop和attr的区别
- 使用 JQueryMobile 点击超链接提示“error loading page” 错误
- jquery简单制作悬浮导航 滚动到哪儿 定位到哪儿