Asp.net通过Jquery操作WebService进行Ajax读写
一说到开始,我们当然需要项目。
首先,创建一个Asp.net Web 应用,然后新增一个名称为“Web 服务”的文件,也就是后缀名为".asmx"的文件,然后需要进行配置一下,在Web.Config中加入如下配置节点:
在HttpHandlers节点中,需要注册:
<add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
然后需要在System.Web下注册WebServices节点:
<webServices>
<protocols>
<add name="HttpSoap"/>
<add name="HttpPost"/>
<add name="HttpGet"/>
<add name="Documentation"/>
</protocols>
</webServices>
配置完毕后,下面开始进行具体的讲解。
1.利用Get方式进行数据读写操作
首先,前台,我们代码如下:
$(document).ready(function () {
$("#Button1").click(function () {
$.ajax({
url: "Ajax/WebService1.asmx/HelloWorld",
type: "get",
data: "name=John&location=Boston",
success: function (result) {
$("#test").html(result.text);
},
error: function (data) {
alert(data.value);
}
});
});
});
后台,我们的代码如下:
using System.Web.Services;
using System.Threading; namespace Nxt.Web.Ajax
{
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
[System.Web.Script.Services.ScriptService]
public class WebService1 : System.Web.Services.WebService
{ [WebMethod]
public string HelloWorld()
{
Thread.Sleep();
return this.Context.Request.QueryString["name"];
}
}
}
得到的结果如我们预料,服务器端返回了“John”。
2.利用Post方式进行数据读写操作。
首先是前端代码:
$(document).ready(function () {
$("#Button1").click(function () {
$.ajax({
url: "Ajax/WebService2.asmx/HelloWorld",
type: "post",
contentType: "application/json", //from backend
dataType: "json", // send to backend
data: '{"name":"test"}',
success: function (result) {
$("#test").html(result.d);
},
error: function (data) {
//alert(data.value);
}
});
});
});
然后是后端的处理过程,在前端代码中,我们可以看到,我们通过contentType: "application/json",表明后台传送到前台的是JSON格式的数据。 而通过dataType: "json",则表明我们往后端传送的也是json类型的数据。
using System.Web.Services;
using System.Threading; namespace Nxt.Web.Ajax
{
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
[System.Web.Script.Services.ScriptService]
public class WebService2 : System.Web.Services.WebService
{
[WebMethod]
public string HelloWorld(string name)
{
Thread.Sleep();
return name;
}
}
}
这样,我们通过Post方式得到了预期的结果。
这里我需要特别说明的是,当用json数据当做参数通过Post方式传入后台的时候,后台的参数名称可以与前台保持一致。
那么我们后台取值的时候,直接把参数拿过来用就行了。在例子里,我的json数据为:{"name":"test"},那么在后台,我需要获取的值,就保存在了参数 string name中了。
直接拿过来用就行了。
3.直接操作后台返回的List对象
前台代码如下:
$(document).ready(function () {
$("#Button1").click(function () {
$.ajax({
url: "Ajax/WebService2.asmx/GetList",
type: "post",
contentType: "application/json", //from backend
dataType: "json", // send to backend
data: '{"i":"10"}',
success: function (result) {
$(result.d).each(function (value) {
$("#test").append(this.toString()+" ");
});
},
error: function (data) {
//alert(data.value);
}
});
});
});
后台代码如下:
[WebMethod]
public List<int> GetList(int i)
{
List<int> list = new List<int>();
do{
list.Add(i);
i--;
}while(i>);
return list;
}
最后,屏幕上打印出了我们需要的数据: 10 9 8 7 6 5 4 3 2 1。
4.直接操作后台返回类对象
前台:
$(document).ready(function () {
$("#Button1").click(function () {
$.ajax({
url: "Ajax/WebService2.asmx/GetModel",
type: "post",
contentType: "application/json", //from backend
dataType: "json", // send to backend
data: '{}',
success: function (result) {
$(result.d).each(function (value) {
debugger;
$("#test").append(this["UserID"].toString() + " " + this["UserName"].toString() + " " + this["UserAddr"].toString());
});
},
error: function (data) {
debugger;
//alert(data.value);
}
});
});
});
后台代码:
[WebMethod]
public Common.TestModel GetModel()
{
return new Common.TestModel { UserID = , UserName = "nxt", UserAddr = "beijing" };
}
5.直接操作返回的dataset数据集
前端代码:
$(document).ready(function () {
$("#Button1").click(function () {
$.ajax({
url: "Ajax/WebService2.asmx/GetDataSet",
type: "post",
dataType: "xml", // send to backend
data: '{}',
success: function (result) {
try {
$(result).find("Table1").each(function () {
$("#test").append($(this).find("ID").text() + " " + $(this).find("Value").text());
});
}
catch (e) {
alert(e);
return;
}
},
error: function (data) {
//alert(data.value);
}
});
});
});
后端代码:
[WebMethod]
public DataSet GetDataSet()
{
DataSet ds = new DataSet();
DataTable dt = new DataTable();
dt.Columns.Add("ID", Type.GetType("System.String"));
dt.Columns.Add("Value", Type.GetType("System.String"));
DataRow dr = dt.NewRow();
dr["ID"] = "scy";
dr["Value"] = "河南理工大学";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["ID"] = "scy1";
dr["Value"] = "河南理工大学1";
dt.Rows.Add(dr);
ds.Tables.Add(dt);
return ds;
}
得到的结果是:scy 河南理工大学scy1 河南理工大学1
符合预期。
最后加一个loading效果的特效,以便备忘:
<style type="text/css">
#loading
{
position:absolute;
top:50%;
left:50%;
}
</style>
$(document).ready(function () {
$('#loading').ajaxStart(function () {
$(this).html("<img src='Images/loading.gif'>").show();
}).ajaxStop(function () {
$(this).hide();
});
});
Asp.net通过Jquery操作WebService进行Ajax读写的更多相关文章
- ASP.net jQuery调用webservice返回json数据的一些问题
之前寒假时,试着使用jQuery写了几个异步请求demo, 但是那样是使用的webform普通页面,一般应该是用 webservice 居多. 最近写后台管理时,想用异步来实现一些信息的展示和修改, ...
- jquery操作ajax返回的页面元素
这两天工作不忙,正好从朋友那里拿到一个某个应用的开发文档,相关数据放在了mongodb里,自己电脑可以本地开启服务器然后通过给的借口来获取数据.由于这是一个比较大比较全的一个完整项目,也没有那么多经历 ...
- jQuery框架-2.jQuery操作DOM节点与jQuery.ajax方法
一.jQuery操作DOM 内部插入操作: append(content|fn):向每个匹配的元素内部追加内容. prepend(content):向每个匹配的元素内部前置内容. 外部插入操作: af ...
- 如何构建ASP.NET MVC4&JQuery&AJax&JSon示例
背景: 博客中将构建一个小示例,用于演示在ASP.NET MVC4项目中,如何使用JQuery Ajax. 步骤: 1,添加控制器(HomeController)和动作方法(Index),并为Inde ...
- json数据的jquery操作和asp.net后台操作
jquery操作 json对象创建 var item0={"a":"val1","b":"val2"}; json对象字 ...
- jQuery入门(2)使用jQuery操作元素的属性与样式
jQuery入门(1)jQuery中万能的选择器 jQuery入门(2)使用jQuery操作元素的属性与样式 jQuery入门(3)事件与事件对象 jQuery入门(4)jQuery中的Ajax()应 ...
- jQuery调用WebService实现增删改查的实现
第一篇博客,发下我自己写的jQuery调用WebService实现增删改查的实现. 1 <!DOCTYPE html> 2 3 <html xmlns="http://ww ...
- Jquery调用Webservice传递Json数组
Jquery由于提供的$.ajax强大方法,使得其调用webservice实现异步变得简单起来,可以在页面上传递Json字符串到Webservice中,Webservice方法进行业务处理后,返回Js ...
- 通过jQuery或ScriptManager以Ajax方式访问服务
1.客户端和服务端 服务端对外提供服务时,可以通过handler或者webservice.handler比较轻便,但是难以对外公开,只有程序员自己知道它到底做了些什么工作.webservice可以将服 ...
随机推荐
- OC第一讲:类和对象
今天终于开始进行OC的学习了 一.首先讲了NSLog NSLog是oc里面的输出语句,其用法和printf差不多,但是还是有差别的 1,NSLog是自动换行的,不用像printf那样还需要加'\n': ...
- Erlang数据类型的表示和实现(5)——binary
binary 是 Erlang 中一个具有特色的数据结构,用于处理大块的“原始的”字节块.如果没有 binary 这种数据类型,在 Erlang 中处理字节流的话可能还需要像列表或元组这样的数据结构. ...
- 【CSharp】C#开发ActiveX插件
这几天Web项目中需要用到ActiveX插件(PS:听说这个是好久好久的东西了...),由于项目中需要调用本地资源所以只能研究研究这位老兄了. 先说说自己学习他的经历,开始的时候是用百度引擎检索自己所 ...
- mysql插入数据与删除重复记录的几个例子(收藏)
mysql插入数据与删除重复记录的几个例子 12-26shell脚本实现mysql数据的批量插入 12-26mysql循环语句插入数据的例子 12-26mysql批量插入数据(insert into ...
- Docker 基础命令 简要入门
本文出自:http://www.cnblogs.com/scoter2008,本文将持续更新所有docker都可以通过man查看帮助:man docker [ps|top|run|...]1.列出正在 ...
- Safari5及以下版本不支持Date的横杠字符串格式
Date构造器有多种方式创建方式 一.new Date() // 当天 var date = new Date() 二.new Date(value) // value 为一个整数 var date ...
- [转]jQuery UI Dialog Modal Popup Yes No Confirm example in ASP.Net
本文转自:http://www.aspsnippets.com/Articles/jQuery-UI-Dialog-Modal-Popup-Yes-No-Confirm-example-in-ASPN ...
- hadoop data 相关开源项目(近期学习计划)
计划学习几个hadoop相关的开源项目: 1.spring hadoop 2.spring batch 3.spring redis 4.spring mongo 相关项目样例:https://git ...
- 怎么运用ZBrush中的Z球制作身体部分
本文主要讲解利用ZSphere[Z球]创建人体的大体轮廓,这是ZBrush®软件制作模型的第一步,这一阶段中我们需要反复调节人体比例结构,为以后深入制作打下基础,具体制作过程如下. 查看更多内容请直接 ...
- 边工作边刷题:70天一遍leetcode: day 71-2
One Edit Distance 要点:有两种解法要考虑:已知长度和未知长度(比如只给个iterator) 已知长度:最好不要用if/else在最外面分情况,而是loop在外,用err记录misma ...