asp.net Jquery後臺資料傳到前臺js進行解析
我們經常用jquery讀取後臺資料,後臺返回資料。後臺資料格式就有很多了,但是js裡面沒有什麼型別之分。所以在解析後臺資料的時候,我們需要根據後臺的資料情況,特殊處理和對待。我這裡後臺用的是asp.net提供的wcf服務,也有ashx一般處理程式。大致原理差不多。C#中我們經常用的物件,有實體物件比如:User;有List集合,一般為返回列表。複雜點的還有物件巢狀物件或者list集合的。不過沒什麼差別,只要看你的資料多少來決定是由js處理資料,還是後臺處理了直接返回最終結果。
1、實體物件:返回是物件的話,在js中,直接就是和你後臺程式碼類中的物件資料是一樣的。
比如下面程式碼,就是獲取到一個物件。直接用它的name屬性就可以獲取到。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
$.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);
}
$( "#btnAdd" ).attr( "disabled" ,
false ); $( "#btnAdd" ).text( "編輯" );
}
}
},
complete: function
(XMLHttpRequest, textStatus) {
},
error: function
(e) {
$( "#btnAdd" ).attr( "disabled" ,
false ); $( "#btnAdd" ).text( "編輯" );
}
});
|
2、返回資料是List集合,包含一些物件:這應用場景也很多。
在js中,對應的一個array陣列。陣列中是你返回的物件實體。可以採用each遍歷。具體可以參考:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
$.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); //json在JS程式碼中的使用方式
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中可以直接解析成物件。
參考:
jquery ajax傳遞物件(陣列)到後臺並解析的實現
json解析函式:var jsonarray= $.parseJSON(str);