参考了别人的文章,我这样尝试去写:

数据源:memberInRoles

 var memberInRoles= {};
for(var i=0;i<sureOptions.length;i++){
memberInRoles["memberInRoles["+i+"].UserId"]=sureOptions[i].value;
memberInRoles["memberInRoles["+i+"].RoleId"]="@Model.RoleId";
}

Controller Action

  [HttpPost]
public JsonResult UserSelectSave(List<MemberInRole> memberInRoles)
{
return Json(new { data = 0, msg = "" });
}

尝试使用$.ajax

             $.ajax({
type: "POST",
dataType: "json",
url: "@Url.Action("UserSelectSave", "RoleManager", new { area = "DeskTop" })",
data: { memberInRoles:memberInRoles },
beforeSend: function () { },
complete: function () { },
success: function (data) {
// format error
if(!data||(!data.status&&data.status!=0)){
alertBox(boxcallback, "0", "提示", "系统参数错误!");
return false;
}
// success
if (data.status == "0") { } else {
alertBox(boxcallback, "0", "提示", data.msg);
return false;
}
},
error: function (data) {
alertBox(boxcallback, "0", "提示", "系统异常,请稍后重试");
return false;
}
});

结果发现接收到的参数为null,继续修改:

$.ajax({
type: "POST",
dataType: "json",
url: "@Url.Action("UserSelectSave", "RoleManager", new { area = "DeskTop" })",
data: { memberInRoles},
beforeSend: function () { },
complete: function () { },
success: function (data) {
// format error
if(!data||(!data.status&&data.status!=0)){
alertBox(boxcallback, "0", "提示", "系统参数错误!");
return false;
}
// success
if (data.status == "0") { } else {
alertBox(boxcallback, "0", "提示", data.msg);
return false;
}
},
error: function (data) {
alertBox(boxcallback, "0", "提示", "系统异常,请稍后重试");
return false;
}
});

结果直接报黄页,刷洗的地址是提交之前的地址,而且把我的参数名称前都加了一个hd字符。

对于“DXWorkFlow.Web.Areas.Desktop.Controllers.RoleManagerController”中方法“System.Web.Mvc.ActionResult
UserManager(Int32, Int32, System.String, System.String)”的不可以为 null
的类型“System.Int32”的参数“parentId”,参数字典包含一个 null 项。可选参数必须为引用类型、可以为 null
的类型或声明为可选参数。
Parameter name: parameters

看别人提交时貌似都是采用$.post方式提交的。

结果使用$.post确可行,实在不明白什么原因。

 $.post("@Url.Action("UserSelectSave", "RoleManager", new { area = "DeskTop" })",
memberInRoles,
function(data){
// format error
if(!data||(!data.status&&data.status!=)){
alertBox(boxcallback, "", "提示", "系统参数错误!");
return false;
}
// success
if (data.status == "") { } else {
alertBox(boxcallback, "", "提示", data.msg);
return false;
}
}
);

实在想不明白$.ajax与$.post方式有什么区别。

如果哪位知道$.ajax与$.post区别具体信息,请赐教。

参考文章:

http://haacked.com/archive/2008/10/23/model-binding-to-a-list.aspx/

http://www.hanselman.com/blog/ASPNETWireFormatForModelBindingToArraysListsCollectionsDictionaries.aspx

http://www.cnblogs.com/birdwudi/archive/2010/08/26/1809511.html

asp.net mvc 后台怎么接受前端返回的array list dictionary的更多相关文章

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

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

  2. 序列化json对象,通过ajax传入asp.net mvc后台

    序列化json对象,通过ajax传入asp.net mvc后台 序列化json对象,通过ajax传入asp.net mvc后台   今天遇到一个问题,准备把组织好的json对象通过jquery.aja ...

  3. asp.net mvc 使用Ajax调用Action 返回数据【转】

      使用asp.net mvc 调用Action方法很简单. 一.无参数方法. 1.首先,引入jquery-1.5.1.min.js 脚本,根据版本不同大家自行选择. <script src=& ...

  4. asp.net mvc后台操作之读写xml控制首页动态页面开关显示

    一.背景 在asp.net mvc项目里,用户需要开拓几个活动版面,并以侧栏的方式呈现在首页右侧,几个活动时间不一致,为避免浏览者在活动未开放之时进入未开放的服务页面.因此不仅需要在活动代码中加入限制 ...

  5. 在asp.net mvc模式中使用PartialView返回部分HTML

    PartialView(返回HTML(局部)) 在asp.net mvc中返回View时使用的是ViewResult,它继承自ViewResultBase 同时它还有个兄弟PartialViewRes ...

  6. Asp.Net Mvc - 在OnResultExecut* 拦截Action返回的HTML

    在Asp.Net MVC项目中通过重写ActionFilterAttribute中的方法,我们就可以在轻松的在Action方法执行前后做一些特殊的操作如:[身份认证.日志记录.内容截取等]. 但是我们 ...

  7. Asp.Net Mvc后台数据验证自测小Demo

    使用过MVC的同学一定不陌生MVC的模型绑定和模型校验,使用起来非常方便,定义好Entity之后,在需要进行校验的地方可以打上相应的Attribute,在Action开始时检查ModelState的I ...

  8. 彻底解决ASP.NET MVC 3 404错误码返回302的问题

    转自:http://blog.csdn.net/mycloudke/article/details/9746333 404状态码:,意味着当在页面上显示用户点击不存在,提高用户体验度,搜索引擎会放弃这 ...

  9. ASP.NET MVC如何在Action中返回脚本并执行

    我们都知道在aspx页面的cs文件中只要用Respos.Write("<script></scritp>")就可以在前台执行脚本 但是在MVC中就不一样了, ...

随机推荐

  1. UDP 构建p2p打洞过程的实现原理(持续更新)

    UDP 构建p2p打洞过程的实现原理(持续更新) 发表于7个月前(2015-01-19 10:55)   阅读(433) | 评论(0) 8人收藏此文章, 我要收藏 赞0 8月22日珠海 OSC 源创 ...

  2. 解决mysql出现“the table is full”的问题

    解决mysql出现“the table is full”的问题 2010-12-20 09:15:17 分类: LINUX 今天中午收到mysql错误日志监控发来的警报,错误日志如下: 101209 ...

  3. 尝试使用word发布博客

    尝试使用WORD2010发布博客   使用博客园博客的主要原因在于能够使用live writer,不用每次都打开网页,当然博客园的大牛很多   如果可以使用方法word,当让更爽,格式的问题将不再是问 ...

  4. C#打开一个文本文件并读写

    OpenFileDialog OFD = new OpenFileDialog(); OFD.Title = "打开第一个文本文件"; OFD.FileName = "* ...

  5. Java ArrayListSerialise

    import java.io.*; import java.util.*; //ArrayListSerialise public class A { public static void main( ...

  6. 有序列表和无序列表、流、格式布局:position

    列表方块: 有序列表和无序列表 ol/ul 例如<ol: style:"list-style:""  "> 1.<ol: style:&quo ...

  7. ubuntu 64bit arm-linux-gcc: No such file or directory 解决

    通过下面这个解决 ubuntu 64bit  arm-linux-gcc: No such file or directory 安装 sudo apt-get install lsb-core解决 h ...

  8. MyBatis-Generator 最佳实践

    为数据库中的表A生成A.java, A.java, A.xml 由于该插件生成的A.java, A.xml会带有example, 不希望生成example 数据库中的字段写有注释, 希望注释能自动生成 ...

  9. JNI字段描述符(转)

    转载自http://fgsink.blog.163.com/blog/static/16716997020124310169911/ “([Ljava/lang/String;)V” 它是一种对函数返 ...

  10. [LeetCode]题解(python):037-Sudoku Solver

    题目来源 https://leetcode.com/problems/sudoku-solver/ Write a program to solve a Sudoku puzzle by fillin ...