<script>
var list=[];//数组
list[0]=1001;
list[1]=1002;
list[1]=1003; var json_data = { selected: list};
$.ajax({
url: '/xk/select',
type: 'POST',
data: json_data,
success: function (j) { },
error: function () { }
});
</script>

上述请求发出后,jquery会把json_data序列化为id=1&selected[]=1001&selected[]=1002&selected[]=1003的形式

假如mvc的action如下,seleted始终为null

public JsonResult select(int[] selected){}

MVC只会把下面两种请求转换为数组:
同名:arr=1001&arr=1002
索引:arr[0]=1001&arr[1]=1002

因此,jquery.ajax不能采用数组方式传递参数,可以换成对象的方式

<script>
var obj= {};//注意这里是对象,不是数组
obj[0] ="1001" ;//中括号属性设置法,等价于obj["0"]="1001";
obj[1] ="1002" ;
obj[1] ="1003" ; //下面就可以发送请求了 var json_data = { selected: obj};
$.ajax({
url: '/xk/select',
type: 'POST',
data: json_data,
success: function (j) { },
error: function () { }
});
</script>

这种处理,请求数据变成了selected[0]=1001&selected[1]=1002&selected[2]=1003的形式,

另外一种方式就是,ajax加traditional : true

<script>
var list= [];//注意这里是数组
list[0] ="1001" ;//中括号属性设置法,等价于student_ids["0"]="1001";
list[1] ="1002" ;
list[1] ="1003" ;
//下面就可以发送请求了 var json_data = { 'selected': list};
$.ajax({
url: '/xk/select',
type: 'POST',
data: json_data,
traditional : true,//注意这里
success: function (j) { },
error: function () { }
});
</script>

通过这种方式,请求变成了selected=1001&selected=1002&selected=1003的形式

public JsonResult Select(int[] selected){}就可以正常接收数组selected了

以上是简单数组绑定,下面考虑复杂对象数组绑定

<script>

var list= [];
list.push( { book_name: “1”, book_version: "1","book_publication":"1","book_author":"1"});
list.push({ book_name: “2”, book_version: "2","book_publication":"2","book_author":"2"});
list.push({ book_name: “3”, book_version: "3","book_publication":"3","book_author":"3"});

$.ajax({
url: '/Book/AddBooks',
type: 'POST',
data: {books:list},
success: function (j) {
},
error: function () {
}
});

</script>

截获的请求发现对象的属性,都自动加了中括号,导致mvc无法绑定到模型上!!

换成对象的形式则能成功绑定

<script>

var list= {};//可以成功进行模型绑定
list[0] = { book_name: “1”, book_version: "1","book_publication":"1","book_author":"1"};
list[1] = { book_name: “2”, book_version: "2","book_publication":"2","book_author":"2"}; 
list[2] = { book_name: “3”, book_version: "3","book_publication":"3","book_author":"3"};

</script>

控制器如下:

public JsonResult AddBooks(BookInfo[] books){}

												

mvc数组绑定-jquery ajax的更多相关文章

  1. Spring MVC Controller与jquery ajax请求处理json

    在用 spring mvc 写应用的时候发现jquery传递的[json数组对象]参数后台接收不到,多订单的处理,ajax请求: "}]}]} $.ajax({ url : url, typ ...

  2. Spring Mvc模式下Jquery Ajax 与后台交互操作

    1.基本代码 1)后台控制器基本代码 @Controller @RequestMapping("/user") public class UserController { @Aut ...

  3. Spring MVC数组绑定

    需求:商品批量删除,用户在页面选择多个商品,批量删除. 关键:将页面选择(多选)的商品id,传到controller方法的形参,方法形参使用数组接收页面请求的多个商品id // 批量删除 商品信息 @ ...

  4. mvc jquery ajax传递数组null问题

    mvc jquery ajax传递数,  areaIds是个int数组.后台action用list<int>接收.当我想传空值时,先用null传递,结果action收到的AreaIds竟然 ...

  5. asp.net mvc 接收jquery ajax发送的数组对象

    <script type="text/javascript"> $(function () { var obj = { name: "军需品", m ...

  6. ASP.NET MVC 后台接收集合参数和 jquery ajax 传值

    MVC 接收参数数组(集合)   示例样本:   public class Person {      public string FirstName { get; set; }      publi ...

  7. 用.NET MVC实现长轮询,与jQuery.AJAX即时双向通信

    两周前用长轮询做了一个Chat,并移植到了Azure,还写了篇博客http://www.cnblogs.com/indream/p/3187540.html,让大家帮忙测试. 首先感谢300位注册用户 ...

  8. ASP.NET MVC数组模型绑定

    在ASP.NET MVC中使用Razor语法可以在视图中方便地展示数组,如果要进行数组模型绑定,会遇到索引断裂问题,如下示例: <input type="text" name ...

  9. jquery ajax/post/get 传参数给 mvc的action

    jquery ajax/post/get 传参数给 mvc的action1.ActionResult Test1    2.View  Test1.aspx3.ajax page4.MetaObjec ...

随机推荐

  1. 【转】嵌入式Linux启动配置文件及脚本

    原文网址:http://blog.csdn.net/shuaishuai80/article/details/6202497 使用Busybox制作根文件系统时,/etc目录非常重要,它包含了嵌入式L ...

  2. Webpack-simple cross-env 不是内部或外部命令问题处理

    本文转载自:https://www.cnblogs.com/stono/p/6984222.html Webpack-simple cross-env 不是内部或外部命令问题处理 学习了:https: ...

  3. [转][C#]常用开源项目

    本文来自:http://www.cnblogs.com/sunxuchu/p/6047589.html 新增两个: 纸壳CMS http://www.zkea.net/zkeacms https:// ...

  4. 根据插件Swipe,结合jQuery封装成的新的jQuery插件

    swipe支持电脑上的自动滑动,也支持手机端的滑动效果.但是每次调用只能支持一个效果或者说一个页面出现n个这样的效果,我们就得调用n次这个插件. 我使用swipe+jQuery使得swip变得方便使用 ...

  5. Android图片高斯模糊的一些方法

    高斯模糊 高斯模糊就是将指定像素变换为其与周边像素加权平均后的值,权重就是高斯分布函数计算出来的值. 一种实现 点击打开链接<-这里是一片关于高斯模糊算法的介绍,我们需要首先根据高斯分布函数计算 ...

  6. 基于SOA的编程模型

    1.webservice是SOA架构的一种实现 ============================================================================ ...

  7. centos7.3给squid搭建代理服务器添加认证nginx

    1先安装 nginx 这里是教程 点击查看 2 然后 使用命令 创建用户 htpasswd -c /etc/nginx/passwd.db baker 输入密码  提示添加完毕 3 查看加密后的用户和 ...

  8. 学习记录:CONCAT()

    连接多个字符串 SELECT * from t_info where phone = CONCAT('12345','678900')

  9. angular性能优化心得

    原文出处 脏数据检查 != 轮询检查更新 谈起angular的脏检查机制(dirty-checking), 常见的误解就是认为: ng是定时轮询去检查model是否变更.其实,ng只有在指定事件触发后 ...

  10. editplus 链接FTP失败,超时

    最近在用editplus链接服务器是出现了超时连接不上的情况 检查后发现FTP配置没问题 后来打开高级设置后发现没有配置端口号 配置后登陆成功