萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> Jquery+asp.net 後台數據傳到前台js進行解析的辦法說明

Jquery+asp.net 後台數據傳到前台js進行解析的辦法說明

   我們經常用jquery讀取後台數據,後台返回數據。後台數據格式就有很多了,但是js裡面沒有什麼類型之分。

  所以在解析後台數據的時候,我們需要根據後台的數據情況,特殊處理和對待。

  我這裡後台用的是asp.net提供的wcf服務,也有ashx一般處理程序。大致原理差不多。

  C#中我們經常用的對象,有實體對象比如:User;有List集合,一般為返回列表。

  復雜點的還有對象嵌套對象或者list集合的。不過沒什麼差別,只要看你的數據多少來決定是由js處理數據,

  還是後台處理了直接返回最終結果。

  1、實體對象:返回是對象的話,在js中,直接就是和你後台代碼類中的對象數據是一樣的。

  比如下面代碼,就是獲取到一個對象。直接用它的name屬性就可以獲取到。

  $.ajax({

  type: "post",

  dataType: "json",

  traditional: true,

  data: {

  oper: "edit",

  sid: id

  },

  url: AjaxUrl,

  success: function(data, textStatus) {

  if (data != null) {

  if (data) {

  $("#name").val(data.Name);獲取到對象了。SetSelectOpertionValue("selectRelation", data.Relation);

  SetSelectOpertionValue("selectaddreason", data.Reason);

  } else {

  $("#btnAdd").attr("disabled", false);

  $("#btnAdd").text("編輯");

  }

  }

  },

  complete: function(XMLHttpRequest, textStatus) {},

  error: function(e) {

  $("#btnAdd").attr("disabled", false);

  $("#btnAdd").text("編輯");

  }

  });

  2、返回數據是List集合,包含一些對象:這應用場景也很多。

  在js中,對應的一個array數組。數組中是你返回的對象實體。可以采用each遍歷。具體可以參考:

  $.ajax({ type: "post", dataType: "json", traditional: true, data: { oper: "list", lc: ID,nm:$("#searchname").val() }, url:sAjaxUrl, success: function (data, textStatus) { if (data != null) { if (data.Instance==null &data.Instance.length==0) { return; } else { var datalist = data.Instance; if (sort == 1) { datalist = datalist.sort( function (a, b) { return (a.Id - b.Id); } ); } else { datalist = datalist.sort( function (a, b) { return (b.Id - a.Id); } ); } var html = ""; //綁定數據到table var tabledata = GetJson(datalist); } } }, complete: function (XMLHttpRequest, textStatus) { }, error: function (e) { } });

  3、如果是復雜嵌套的話,也是對象了。js中會完全和後台對應。你遍歷即可。

  現在很多時候,後台返回給前台一般都是用json了。json在js中可以直接解析成對象。

copyright © 萬盛學電腦網 all rights reserved