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、返回List集合方法的调用
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>
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(""); //这里只取部分键、值显示 $("#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代码:
<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() { $.ajax({ url: "books.xml", dataType: "xml", success: function(xmlData) { $("#msg").html(""); $(xmlData).find("books>book").each(function() { $("#msg").append("====new book===="); $("#msg").append("<li>name:" + $(this).find("name").text() + "</li>"); $("#msg").append("<li>author:" + $(this).find("author").text() + "</li>"); $("#msg").append("<li>wordCount:" + $(this).find("wordCount").text() + "</li>"); $("#msg").append("<li>price:" + $(this).find("price").text() + "</li>"); }); $("#msg").css("color", "#0000FF"); }, error: function(err) { $("#msg").css("color", "#FF0000").html("access faield:" + err); } }); return false; }); }); </script>
运行结果:
更多jQuery.ajax()调用asp.net后台方法相关文章请关注PHP中文网!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Kaedah penggunaan simbol dalam bahasa C meliputi aritmetik, tugasan, syarat, logik, pengendali bit, dan lain-lain. Operator aritmetik digunakan untuk operasi matematik asas, pengendali tugasan digunakan untuk penugasan dan penambahan, penolakan, pendaraban dan tugasan pembahagian, pengendali keadaan digunakan untuk operasi yang digunakan untuk operasi yang digunakan untuk Operasi Bit untuk Penunjuk null, penanda akhir fail, dan nilai bukan angka.

Dalam bahasa C, watak -watak khas diproses melalui urutan melarikan diri, seperti: \ n mewakili rehat garis. \ t bermaksud watak tab. Gunakan urutan melarikan diri atau pemalar watak untuk mewakili watak khas, seperti char c = '\ n'. Perhatikan bahawa backslash perlu melarikan diri dua kali. Platform dan penyusun yang berbeza mungkin mempunyai urutan melarikan diri yang berbeza, sila rujuk dokumentasi.

Dalam C, jenis char digunakan dalam rentetan: 1. Simpan satu watak; 2. Gunakan array untuk mewakili rentetan dan berakhir dengan terminator null; 3. Beroperasi melalui fungsi operasi rentetan; 4. Baca atau output rentetan dari papan kekunci.

Perbezaan antara multithreading dan asynchronous adalah bahawa multithreading melaksanakan pelbagai benang pada masa yang sama, sementara secara tidak sengaja melakukan operasi tanpa menyekat benang semasa. Multithreading digunakan untuk tugas-tugas yang berintensifkan, sementara asynchronously digunakan untuk interaksi pengguna. Kelebihan multi-threading adalah untuk meningkatkan prestasi pengkomputeran, sementara kelebihan asynchronous adalah untuk tidak menghalang benang UI. Memilih multithreading atau asynchronous bergantung kepada sifat tugas: tugas-tugas intensif pengiraan menggunakan multithreading, tugas yang berinteraksi dengan sumber luaran dan perlu menyimpan respons UI menggunakan asynchronous.

Dalam bahasa C, perbezaan utama antara char dan wchar_t adalah pengekodan aksara: char menggunakan ASCII atau memanjangkan ASCII, WCHAR_T menggunakan unicode; Char mengambil 1-2 bait, wchar_t mengambil 2-4 bait; Char sesuai untuk teks bahasa Inggeris, WCHAR_T sesuai untuk teks berbilang bahasa; CHAR disokong secara meluas, WCHAR_T bergantung kepada sama ada penyusun dan sistem operasi menyokong Unicode; Char adalah terhad dalam pelbagai watak, WCHAR_T mempunyai pelbagai watak yang lebih besar, dan fungsi khas digunakan untuk operasi aritmetik.

Dalam bahasa C, penukaran jenis char boleh ditukar secara langsung kepada jenis lain dengan: Casting: Menggunakan aksara pemutus. Penukaran Jenis Automatik: Apabila satu jenis data dapat menampung jenis nilai lain, pengkompil secara automatik menukarkannya.

Arus char menyimpan urutan watak dalam bahasa C dan diisytiharkan sebagai array_name char [saiz]. Unsur akses diluluskan melalui pengendali subskrip, dan elemen berakhir dengan terminator null '\ 0', yang mewakili titik akhir rentetan. Bahasa C menyediakan pelbagai fungsi manipulasi rentetan, seperti strlen (), strcpy (), strcat () dan strcmp ().

Tiada fungsi jumlah terbina dalam dalam bahasa C, jadi ia perlu ditulis sendiri. Jumlah boleh dicapai dengan melintasi unsur -unsur array dan terkumpul: Versi gelung: SUM dikira menggunakan panjang gelung dan panjang. Versi Pointer: Gunakan petunjuk untuk menunjuk kepada unsur-unsur array, dan penjumlahan yang cekap dicapai melalui penunjuk diri sendiri. Secara dinamik memperuntukkan versi Array: Perlawanan secara dinamik dan uruskan memori sendiri, memastikan memori yang diperuntukkan dibebaskan untuk mengelakkan kebocoran ingatan.
