所以在解析後台數據的時候,我們需要根據後台的數據情況,特殊處理和對待。
我這裡後台用的是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遍歷。具體可以參考:
[Jquery操作js數組及對象示例]
demo:
復制代碼 代碼如下:
$.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) {
}
});
復制代碼 代碼如下:
<script type="text/javascript">
//假如返回的是:
var json = "['2010-4-2','2010-4-1','2010-5-2']";
var dateArray = eval(json);
for(i in dataArray)
{
document.write(dataArray[i]);
}
</script>
或者:
復制代碼 代碼如下:
$.each(data.comments, function(i, item) {
$("#info").append(
"<div>" + item.id + "</div>" +
"<div>" + item.nickname + "</div>" +
"<div>" + item.content + "</div><hr/>");
});
3、如果是復雜嵌套的話,也是對象了。js中會完全和後台對應。你遍歷即可。
現在很多時候,後台返回給前台一般都是用json了。json在js中可以直接解析成對象。