Jquery+asp.net后台数据传到前台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遍历。具体可以参考:
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{
vardatalist=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); }
);
}
varhtml="";
//绑定数据到table
vartabledata=GetJson(datalist);
}
}
},
complete:function(XMLHttpRequest,textStatus){ },
error:function(e){
}
});
或者: 3、如果是复杂嵌套的话,也是对象了。js中会完全和后台对应。你遍历即可。 现在很多时候,后台返回给前台一般都是用json了。json在js中可以直接解析成对象。
<scripttype="text/javascript">
//假如返回的是:
varjson="["2010-4-2","2010-4-1","2010-5-2"]";
vardateArray=eval(json);
for(iindataArray)
{
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/>");
});
相关文章