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);
    
}

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数组及对象示例]

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传递对象(数组)到后台并解析的实现  

http://www.suchso.com/UIweb/jquery-ajax-post-array-csharp-json.html 


json解析函数:var jsonarray= $.parseJSON(str);


转发注明:IT分享  http://www.suchso.com

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值