ホームページ >バックエンド開発 >C#.Net チュートリアル >jQuery.ajax() は asp.net バックグラウンド メソッドを呼び出します
JQuery の $.ajax() を使用すると、asp.net のバックグラウンド メソッドを簡単に呼び出すことができます。
まず簡単な例でウォームアップしましょう。
1. パラメーターなしのメソッド呼び出し
C# バックグラウンド コード:
using System.Web.Services; [WebMethod] public static string sayHi() { return "Hi,Welcome to China!"; }
注: 1. メソッドは静的メソッドである必要があり、[WebMethod] の宣言が必要です。
html コード:
<div> <asp:Button ID="btnClick" runat="server" Text="click me" /> <br /> <span id="msg"></span> </div>
jQuery コード:
<script type="text/javascript"> $(document).ready( function() { $("#btnClick").bind("click", function() { $.ajax({ type: "post", url: "ajaxHandler.aspx/sayHi", contentType: "application/json; charset=utf-8", dataType: "json", success: function(data) { $("#msg").css("color", "#0000FF").html(data.d); }, error: function(err) { $("#msg").css("color", "#FF0000").html("access faield:" + err); } }); return false; }); }); </script>
実行結果:
firebug を介して json によって返されるデータ形式を明確に確認できるため、データをフェッチするときに data.d が必要になります。
2. パラメーターを使用したメソッド呼び出し
C# バックグラウンド コード:
[WebMethod] public static string sayHi(string address, string name) { return "Hi," + address + " " + name; }
html コード:
<div> <asp:Button ID="btnClick" runat="server" Text="click me" /> address:<asp:TextBox ID="txtAddress" runat="server"></asp:TextBox> family name:<asp:TextBox ID="txtName" runat="server"></asp:TextBox> <br /> <span id="msg"></span> </div>
jQuery コード:
<script type="text/javascript"> $(document).ready( function() { $("#btnClick").bind("click", function() { var add = $("#txtAddress").val(); var txtname = $("#txtName").val(); $.ajax({ type: "post", url: "ajaxHandler.aspx/sayHi", data: "{'address':'" + add + "','name':'" + txtname + "'}", contentType: "application/json; charset=utf-8", dataType: "json", success: function(data) { $("#msg").css("color", "#0000FF").html(data.d); }, error: function(err) { $("#msg").css("color", "#FF0000").html("access faield:" + err); } }); return false; }); }); </script>
実行結果
3. リスト コレクションを返すメソッドの呼び出し
C# バックグラウンド コード:
[WebMethod] public static List<string> sayHi(string address, string name) { List<string> list = new List<string>(); for (int i = 0; i < 10; i++) { list.Add("Hi:" + i.ToString()); } list.Add("Hi:" + address + " " + name); return list; }
html コード:
<div> <asp:Button ID="btnClick" runat="server" Text="click me" /> address:<asp:TextBox ID="txtAddress" runat="server"></asp:TextBox> family name:<asp:TextBox ID="txtName" runat="server"></asp:TextBox> <br /> <ul id="msg"> </ul> </div>
jQuery コード:
<script type="text/javascript"> $(document).ready( function() { $("#btnClick").bind("click", function() { var add = $("#txtAddress").val(); var txtname = $("#txtName").val(); $.ajax({ type: "post", url: "ajaxHandler.aspx/sayHi", data: "{'address':'" + add + "','name':'" + txtname + "'}", contentType: "application/json; charset=utf-8", dataType: "json", success: function(data) { $("#msg").html(""); $(data.d).each(function() { $("#msg").append("<li>" + this + "</li>"); }); $("#msg").css("color", "#0000FF"); }, error: function(err) { $("#msg").css("color", "#FF0000").html("access faield:" + err); } }); return false; }); }); </script>
実行結果:
4. SortedList
C# の背景コード:
[WebMethod] public static SortedList<string, string> sayHi(string address, string name) { SortedList<string, string> sl = new SortedList<string, string>(); for (int i = 0; i < 10; i++) { sl.Add(i.ToString() + "_key", i.ToString() + "_value"); } sl.Add("_key", "_value " + address + " " + name); return sl; }html コード:
<div> <asp:Button ID="btnClick" runat="server" Text="click me" /> address:<asp:TextBox ID="txtAddress" runat="server"></asp:TextBox> family name:<asp:TextBox ID="txtName" runat="server"></asp:TextBox> <br /> <ul id="msg"> </ul> </div>jクエリ コード:
<script type="text/javascript"> $(document).ready( function() { $("#btnClick").bind("click", function() { var add = $("#txtAddress").val(); var txtname = $("#txtName").val(); $.ajax({ type: "post", url: "ajaxHandler.aspx/sayHi", data: "{'address':'" + add + "','name':'" + txtname + "'}", contentType: "application/json; charset=utf-8", dataType: "json", success: function(data) { $("#msg").html(""); //这里只取部分键、值显示 $("#msg").append("<li>" + data.d["0_key"] + "</li>"); $("#msg").append("<li>" + data.d["1_key"] + "</li>"); $("#msg").append("<li>" + data.d["2_key"] + "</li>"); $("#msg").append("<li>" + data.d["_key"] + "</li>"); $("#msg").css("color", "#0000FF"); }, error: function(err) { $("#msg").css("color", "#FF0000").html("access faield:" + err); } }); return false; }); }); </script>実行結果:
5. 操作 xml
Xml ファイル コード:<?xml version="1.0" encoding="utf-8" ?> <books> <book> <name>ASP.NET 3.5高级程序设计(第2版)</name> <author>麦克唐纳博思工作室</author> <wordCount>2034000</wordCount> <price>76</price> </book> <book> <name>ASP.NET 3.5入门经典</name> <author>(荷兰)史潘加斯(Spaanjaars,I.)</author> <wordCount>1046000</wordCount> <price>78.5</price> </book> <book> <name>C#高级编程(第5版)上下卷</name> <author>(美)内格尔(Nagel.C) 等著</author> <wordCount>24770000</wordCount> <price>124</price> </book> <book> <name>ASP.NET AJAX实战</name> <author>(美)麦克卢尔,(美)格拉维奇,(美)欧尔 等著</author> <wordCount>511000</wordCount> <price>44</price> </book> <book> <name>ASP.NET程序开发范例宝典(C#)(第2版)</name> <author>张跃延,苏宇,贯伟红</author> <wordCount>1419000</wordCount> <price>71.2</price> </book> </books>html コード:
rrreええ
jQueryコード:<div> <asp:Button ID="btnClick" runat="server" Text="click me" /> address:<asp:TextBox ID="txtAddress" runat="server"></asp:TextBox> family name:<asp:TextBox ID="txtName" runat="server"></asp:TextBox> <br /> <ul id="msg"> </ul> </div>実行結果:
asp.net バックグラウンド メソッドの呼び出し jQuery.ajax() に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。