所以在解析后台数据的时候,我们需要根据后台的数据情况,特殊处理和对待。
我这里后台用的是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遍历。具体可以参考:
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中可以直接解析成对象。