首頁 >web前端 >js教程 >Jquery getJSON方法用法的詳細分析

Jquery getJSON方法用法的詳細分析

巴扎黑
巴扎黑原創
2017-07-03 09:28:251157瀏覽

本篇文章主要是對Jquery getJSON方法進行了詳細的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助

準備工作
·Customer類別

程式碼如下:

public class Customer
{
    public int Unid { get; set; }
    public string CustomerName { get; set; }
    public string Memo { get; set; }
    public string Other { get; set; }
}

·服務端處理(Json_1.ashx )

代碼如下:

##Customer customer = new Customer

      { Unid=1,CustomerName="宋江",Memo="天魁星",Other="黑三郎"};
string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(customer);

context.Response.Write(strJson);



## (一)Jquery. getJSON

方法定義:jQuery.getJSON( url, data, callback )


透過get請求得到json資料

#·url用於提供json資料的位址頁
·data(Optional)用於傳送到伺服器的鍵值對·callback(Optional)回呼函數
,json資料請求成功後面的處理函數

程式碼如下:


function(data, textStatus) {        // data是一個json物件

      收到


##$.getJSON(    "webdata/Json_1.ashx",    function(data) {
       $ $ $ ("#pmessage").text(data.CustomerName);
    }
);

向Json_1.ashx位址請求json數據,接收到資料後,在function中處理data資料。 這裡的data的資料是一筆記錄,對應於一個customer實例,其中的資料以k/v形式存在。即以[object,object]數組形式存在。
{"Unid":1,"CustomerName":"宋江","Memo":"天魁星","Other":"黑三郎"}

所以在訪問時,以data. Property來訪問,下面以k/v循環來打印這條宋江的記錄:


代碼如下:

$.getJSON(
    "webdata/Json_1.ashx" ,
    function(data) {

        var tt="";

        $.each(data, function(k, v) {
115 ;br/>";

        })

        $("#pmessage").html(tt);

});




Unid:1
CustomerName:宋江
Memo:天魁星
Other:黑三郎


(2)物件陣列












## Ashx檔案(Json_1.ashx)修改:


程式碼如下:

List _list = new List();

Customer customer = new Customer

       { Unid=1,CustomerName="宋江",Memo="天魁星",Other="黑三郎"};
Customer customer2 = new Customer        { Unid = 2, CustomerName = "吳吳" , Memo = "天機星", Other = "智多星" };

_list.Add(customer);

_list.Add(customer2);
string strJson = Newtonsoft.Json.JsonConvert. SerializeObject(_list);

#########它產生的json物件的###字串###是:######[{"Unid":1,"CustomerName" :"宋江","Memo":"天魁星","Other":"黑三郎"},###{"Unid":2,"CustomerName":"吳用","Memo":"天機星","Other":"智多星"}]###

這裡可以看到做為集合的json物件不是再一筆記錄,而是2筆記錄,是一個[[object,object]]陣列:[object,object][object,object],而每個[ object,object]表示一筆記錄,對應一個Customer,其實也是k/v的形式,而這個v就是一個Customer對象,而這個k是從0開始的索引

##程式碼如下:

$.getJSON(
    "webdata/Json_1.ashx",
    function(data) {
       $.each(unction(data) {
       $.each((data, each(), function(k, v) {
            alert(k);
#       });
});



列表json物件的方法:

程式碼如下:


$.getJSON(
    "webdata/Json_1.ashx",
    function(數據) {
        var tt = "";
        $.each(data, function(k, v) {
             tt += kk + ":" + vv + "
";
            });
        });
  ;

結果:
Unid:1
CustomerName:宋江
Memo:天魁星
Other:黑三郎
Unid:2
CustomerName:吳用
Memo:天機星
Other:智多星
 

這裡用了嵌套循環,第一個循環用於從List中遍歷Customer對象,第二個循環用來從Customer物件遍歷Customer物件的

屬性,也就是k/v對。

以上是Jquery getJSON方法用法的詳細分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn