ajax 提交数组 泛型集合
ajax 提交数组 泛型集合
发表于2015/12/31 14:26:29 5117人阅读
分类: mvc asp.net webapi ORM
转载:http://blog.csdn.net/lingxyd_0/article/details/10428785
在项目上用到了批量删除与批量更改状态,前台使用了EasyUI的DataGrid,用到了批量更改数据状态功能。
在前台可以获取每条数据的ID,但是如何通过数组方式传递给后台?
通过昨晚的各种方式的调试,终于得出了答案! 在此作为备忘。
目前有两种方式可行:
方式一
前台代码:
// 方式一
var _list = {}; for (var i = 0; i < checkedRow.length; i++) {
_list["selectedIDs[" + i + "]"] = checkedRow[i].ID;
} $.ajax({
url: '@Url.Action("SetCallBackStatus")',
//data: { "selectedIDs": _list },
data: _list,
dataType: "json",
type: "POST",
//traditional: true,
success: function (responseJSON) {
// your logic
alert('Ok');
}
});
注意:
1、_list 是一个对象
2、_list中的属性需要结合后台参数名称,例如”selectedIDs“,组合成类似:selectedIDs[0],selectedIDs[1]...等Request.Params
这里是最重要的,否则后台认不出来。这种方式也可以传递自定义类的数组。组合方式就是selectedIDs[0].FirstName,selectedIDs[0].LastName,selectedIDs[1].FirstName,selectedIDs[1].LastName...
3、ajax的data参数直接指定为_list
后台代码:
public ActionResult SetCallBackStatus(List<int> selectedIDs)
{
string result = "ok";
string errMsg = ""; return this.JsonFormat(new { result = result, errMsg = errMsg });
}
方式二
前台代码:
var _list = [];  
for (var i = 0; i < checkedRow.length; i++) {
    _list[i] = checkedRow[i].ID;
}  
$.ajax({
    url: '@Url.Action("SetCallBackStatus")',
    data: { "selectedIDs": _list },
    //data: _list,
    dataType: "json",
    type: "POST",
    traditional: true,
    success: function (responseJSON) {
        // your logic
        alert('Ok');
    }
});  
注意:
1、_list 是一个数组。
2、ajax参数中data为{“selectedIDs”:_list}
3、这种方式比较重要的 traditional:true。或者将2、中的 _list参数转换一下$.param(_list,true)。这里其实就是将_list作为传统的方式传递给后台。Jquery默认是做了转换的。据说是为了使用PHP。。。。后台语言而做的。其实也就是自动在参数后面追加了”[]“。
针对自定义的类,也可以通过方式一jquery ajax传递给后台
例如:
// 自定义Person类
public class Person
{
public string FirstName { get; set; }
public string LastName { get; set; }
}
// 后台Action
public ActionResult SetCallBackStatus(List<Person> selectedIDs)
{
string result = "ok";
string errMsg = ""; return this.JsonFormat(new { result = result, errMsg = errMsg });
}
此时前台js可以这样写:
            var pprds = [];
            for (var i = 0; i < rows.length; i++) {
                var pprd={
                    "FirstName":rows[i].FirstName
                    "LastName":rows[i].LastName
                };
                pprds[i]=pprd;
            }
            $.ajax({
                type: "Post",
                url: '../api/PO_PPR/UpdatePPPRD_Amount',
                contentType: "application/json; charset=utf-8",
                data:JSON.stringify(pprds),
                beforeSend: function () {
                    layer.load();
                },
                complete: function () {
                    layer.close(layer.load());
                },
                success: function (d) {
                }
            });
或者:
var _list = {};  
for (var i = 0; i < checkedRow.length; i++) {
    _list["selectedIDs[" + i + "].FirstName"] = checkedRow[i].FirstName;
    _list["selectedIDs[" + i + "].LastName"] = checkedRow[i].LastName;
}  
$.ajax({
    url: '@Url.Action("SetCallBackStatus")',
    data: _list,
    dataType: "json",
    type: "POST",
    success: function (responseJSON) {
        // your logic
        alert('Ok');
    }
}); 
ajax 提交数组 泛型集合的更多相关文章
- ajax 提交数组 泛型集合(二)
		
最近在项目中,使用 mvc架构,model层使用code first 碰见一个问题,前台json传递数据给后台action的复杂对象,发现复杂对象中的list范型集合并没有获取到数据. 研究半天,终于 ...
 - ajax 提交数组 泛型集合(嵌套集合)
		
直接上代码 后台接口: A类型中嵌套了 List<B> B类型中嵌套了 List<C> [HttpPost] public string Post(A a) { return ...
 - mvc ajax提交数组参数(转)
		
http://blog.csdn.net/lonestar555/article/details/10192595/ 在action中的参数以数组方式接收数据 一.表单方式 1.提交Form < ...
 - ajax 提交数组,mybatis 数组接受
		
function jinxingzhong() { // 配送单编号:psd2017090103 var divHtml = ""; $.ajax({ type: "PO ...
 - 使用javaScript解决asp.net中mvc使用ajax提交数组参数的匹配问题
		
想到在asp.net的mvc中如果使用ajax向服务端传递参数时如果参数是一个类或者是个数组(或List集合)以及更复杂的对象时,服务端总是会发生取不到值的情况,当然网上也有很多解决的例子,但都是在服 ...
 - ajax提交数组至后台,无法获取值得问题
		
$(".delAll_btn").click(function(){ var checkStatus = table.checkStatus('userList'), data = ...
 - c#重点[集合类型]异常,数组,集合ArrayList,List<>,hashTable,hashtable泛型(Dictionary)
		
1.foreach[对一些数组或集合进行遍历] foreach(类型 变量名 in 集合对象){语句体} //定义一个数组 ,,,,, }; foreach(var i in sNum1) { Con ...
 - MVC中用ajax提交json对象数组
		
应用场景:在前端用ajax向服务器提交json对象数组,在controller的以对象数组作为函数的参数,提交的json数组直接转为服务器端的对象数组. 如: 要将json对象数组[{Id:1,Nam ...
 - C#重的数组、集合(ArrayList)、泛型集合(list<T>)三者比较及扩展延伸……
		
本来我只想总结下数组.集合(ArrayList).泛型集合(list<T>)三者的比较的,可以一写下来要扩展的知识点有点多了,只能写一个小的知识点列表了如下: 1.数组.集合(ArrayL ...
 
随机推荐
- 【SparkStreaming学习之四】 SparkStreaming+kafka管理消费offset
			
环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...
 - 2018-2019-20175205 实验三敏捷开发与XP实践《Java开发环境的熟悉》实验报告
			
2018-2019-20175205 实验三敏捷开发与XP实践<Java开发环境的熟悉>实验报告 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)>&l ...
 - angular2 ----字符串、对象、base64 之间的转换
			
1. JSON对象转化为字符串 let obj = { "name":Ayinger; "sex":"女"; } let str = JSO ...
 - centos6.9 PHP的编译安装并连接nginx
			
1.安装yum -y install libxml2-devel openssl-devel bzip2-devel libmcrypt-devel 解决php包的依赖关系,可能libmcrypt会报 ...
 - windows下使用electron+sqlite3
			
1.前置条件 1.1:安装 python2.7.python 若是有问题,如果之前安装过多个版本,则必须 npm config set python "/path/python.exe&qu ...
 - webviewplugin
			
https://blog.csdn.net/qq_39197547/article/details/85007418 https://www.cnblogs.com/pjl43/p/9866753.h ...
 - Haproxy官方文档翻译(第二章)配置Haproxy 附英文原文
			
2.配置 HAProxy 2.1 配置文件格式 Haproxy的配置过程包含了3部分的参数资源:- 命令行中的参数,此种参数总是享有优先权被使用- 配置文件中global节点中的参数,此种参数是进程范 ...
 - bash  基础命令
			
bash的基础特性(): () 命令历史 history 环境变量: HISTSIZE:命令历史记录的条数: HISTFILE:~/.bash_history: HISTFILESIZE:命令历史文件 ...
 - Java基础学习-Random类和Java数组
			
1.随机数类(Random) package com.denniscui; import java.util.Random; /* * Random:用于产生随机数 * * 使用步骤: * ...
 - Summary on deep learning framework --- Theano && Lasagne
			
Summary on deep learning framework --- Theano && Lasagne 2017-03-23 1. theano.function outp ...