可能使用JQuery Ajax传值到后台一个字符串,或者序列化后的表单大家都使用过,但是某些项目,需要我们一次传值一个数组到后台,这个时候有什么好的办法呢?

1.JS将数组转换为一个字符串,然后传值到后台,不方便

  比如把一个[1,2,3,4,5]的数组,转换为一个 var str="1,2,3,4,5"; 的字符串 ,然后传递到后台后,再用.net的 split(',') 分离,这样用起来十分别扭,而且还要考虑数组中是否会存在分割字符串的问题

2.使用 JSON.stringify() 方法,方便,简单粗暴。

  昨天晚上小朱又遇到了提交数组的问题,于是和朋友小飞商量了下,之前知道JQuery 有 stringify() 这个方法,也一直不知道咋用,昨天小飞知道小朱这个问题后,教了下小朱这个方法,解决了提交数组的问题

  现学现卖,于是今天和园友们分享这个实用的方法

首先,引入必须的JQuery文件

然后从你的页面中得到一个数组,这根据你的实际需求,可能是用户输入,或者自己从table表格里抓取

比如小朱需要抓取类似 学号,当前边的checkbox被选中时候,就把这个学号,放在数组里

现在小朱得到了一个名字为 arrId 的数组,当然你也可以通过其它方法来拼凑自己的数组,这个不是本文的重点,本文的重点在下面,当你得到这个数组后,如后传递到后台,和后台交互

传递数组嘛,上文就是为了拼凑这样的一个数组:

得到这个数组后,我们使用ajax传递到后台:

 //2.传后台
$.ajax({
type: "Post",
url: "manager.aspx/DeleteMore",
data: JSON.stringify({ arr: arrId }),
contentType: "application/json;charset=utf-8",
dataType: "json",
success: function (data) {
if (data.d == "Y") {
alert("批量删除成功!");
window.location.reload();
} }
});

所以,我们需要在本页后台,写一个WebMethod(我的这个页面名字叫做manage.aspx,请读者朋友根据自己的页面记得相应改动)

[WebMethod]
public static string DeleteMore(List<string> arr)
{
StringBuilder sb = new StringBuilder();
foreach (var item in arr)
{
sb.Append(item + ",");
}
sb.Remove(sb.Length - , ); string sqlDelete = "UPDATE stuapply_Info SET Status=1 WHERE ApplyId IN (" + sb.ToString() + ")"; int r = DBUtility.DbHelperSQL.ExecuteSql(sqlDelete); if (r > )
{
return "Y";
}
else
{
return "N";
}
}

WebMethod需要引入命名空间:

using System.Web.Services;

那么,按F5就可以正常运行了。

===========总结============

上文可能说的比较啰嗦,因为小朱担心朋友们看不懂啦,下边简单做一个总结:

1.引入JS文件

2.拼凑出来一个数组

3.ajax后台交互

 $.ajax({
type: "Post",
url: "页面名.aspx/load",
data: JSON.stringify({ arr: arrId }),
contentType: "application/json;charset=utf-8",
dataType: "json",
success: function (data) {
alert("操作成功!");
} }
});

4.后台引入命名空间,写WebMethod

[WebMethod]
public static string load(List<string> arr)
{
StringBuilder sb = new StringBuilder();
foreach (var item in arr)
{
sb.Append(item + ",");
}
sb.Remove(sb.Length - , ); //sb.ToString() 为 1,2,3,4 可以用在SQL语句的WHERE ... IN ... //当然你也可以根据自己的业务逻辑不同,使用List<string> //记得最后要 return "Y";
}

把这个使用的方法记录下来,分享给朋友们,方便朋友们学习,方便自己以后查阅复习!

JQuery ajax 异步传一个数组到 .net后台的更多相关文章

  1. jQuery ajax如何传多个值到后台页面,举例:

    一.js代码 <script type="text/JavaScript">$("#save_change_<{$aff.Id}>"). ...

  2. IE8/9 JQuery.Ajax 上传文件无效

    IE8/9 JQuery.Ajax 上传文件有两个限制: 使用 JQuery.Ajax 无法上传文件(因为无法使用 FormData,FormData 是 HTML5 的一个特性,IE8/9 不支持) ...

  3. Jquery Ajax 异步设置Table中某列的值

    可根据table中某列中的ID去改变某列的值! 只是参考,实际应用中不能这样做的,如果有很多行,频繁访问服务器,服务器是顶不住的! JS: $(document).ready(function () ...

  4. 使用 jQuery Ajax 异步登录,并验证用户输入信息(maven)

    使用 jQuery Ajax 异步登录,并验证用户输入信息(maven) 本篇内容: (1)上一篇是使用同步的请求实现登录,并由 Servlet 决定登陆后下一步做哪些事情,本篇使用 jQuery A ...

  5. jQuery ajax上传文件实例

    jQuery ajax上传文件实例 <form id="form" enctype="multipart/form-data"><input ...

  6. jQuery Ajax(异步请求)

    jQuery异步请求 原始的异步请求是需要创建的 XMLHttpRequest 对象.(IE5,6不支持)目前很多浏览器都支持XMLHttpRequest对象 jQuery ajax常用的回调函数:b ...

  7. jquery ajax异步调用

    写程序的第一步都要知其然,至于知其所以然就要看个人的爱好了.下面说一下web开发中经常用的ajax. 这里是用的jquery框架实现的ajax异步调用.废话少说先上代码.(asp.net开发) var ...

  8. JQuery $.ajax(); 异步访问完整参数

    $.ajax 完整参数   jquery中的ajax方法参数 url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post ...

  9. jquery Ajax异步请求之session

    写了一个脚本,如下: $(function () { $("#btnVcode").click(function () { var receiveMobile = $(" ...

随机推荐

  1. HDFS 核心原理

    HDFS 核心原理 2016-01-11 杜亦舒 HDFS(Hadoop Distribute File System)是一个分布式文件系统文件系统是操作系统提供的磁盘空间管理服务,只需要我们指定把文 ...

  2. apache虚拟主机访问原理

    www.a.com www.b.org www.c.net 都放在10.0.0.10这个服务器上 那么客户访问这三个域名 服务器是怎么分辨访问的是哪个目录呢 GET http://download.m ...

  3. json_encode 中文乱码

    用PHP的json_encode来处理中文的时候, 中文都会被编码, 变成不可读的, 类似"\u***"的格式, 还会在一定程度上增加传输的数据量. 而在PHP5.4, 这个问题终 ...

  4. openssl pem 生成公钥和私钥及文件

    openssl pem.h 中提供了关于pem格式密钥对的操作接口 通常使用.pem的格式文件来保存openssl 生成的密钥对: 在终端下 cat xxx.pem 可以看到 p.p1 { margi ...

  5. python3 函数的形参、实参、位置参数、默认参数、关键字参数以及函数的递归

    python 版本 3.5 #Author by Andy#_*_ coding:utf-8 _*_def func(x,y=2): print('我是形参%s'%x) print('我是默认参y-- ...

  6. 获取Mac地址

    netapi32.lib#include <NB30.h>; typedef struct _ASTAT_ { ADAPTER_STATUS adapt; NAME_BUFFER Name ...

  7. windows安装postgres源代码

    http://blog.csdn.net/adrastos/article/details/9093739 1. 下载PostgreSQL的源代码.解压. 2. 在Windows平台下编译需要跳过一个 ...

  8. jQuery刷新包含的<jsp:include>页面

    jQuery刷新包含页面 JQuery刷新包含页面,以下两种形式均可: <%@include file="../include/header.jsp" %>   < ...

  9. Java8新特性——接口的默认方法和类方法

    Java8新增了接口的默认方法和类方法: 以前,接口里的方法要求全部是抽象方法,java8以后允许在接口里定义默认方法和类方法: 不同的是: 默认方法可以通过实现接口的类实例化的对象来调用,而类方法只 ...

  10. 油猴 greasemonkey 背景音乐 火狐 chrome 背景音乐

    火狐,chrome背景音乐 http://www.w3school.com.cn/tags/tag_audio.asp js插入背景音乐,猴油脚本使用 var audio = document.cre ...