现在位置首页 / 项目实战 /正文

Jquery+asp.net 后台数据传到前台js进行解析的办法说明

作者: IT小兵 | 2014年3月27日| 热度:℃ | 评论: |参与:

我们经常用jquery读取后台数据,后台返回数据。后台数据格式就有很多了,但是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遍历。具体可以参考:

[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中可以直接解析成对象。

参考:

Jquery ajax传递对象(数组)到后台并解析的实现  

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


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


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

点击阅读本文所属分类的更多文章: 项目实战 。和高手一起交流:346717337
友荐云推荐

未注明转发、原文均为本站原创。分享本文请注明 原文链接

给您更多信息和帮助

在这里您可以找到更多:

技术交流群:346717337 Jquery插件交流

投稿:[email protected]

承接:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/业务咨询

echarts教程系列
本月最热文章

微信扫一扫,徜徉悠嘻网,您的休闲乐园

微信公众号:快乐每一天

随机文章
标签

技术交流群:346717337

投稿:[email protected]

专业专注:企业网站门户/微网站/微商城/CMS系统/微信公众号运营/付费问题咨询