ashx 后台 解析json_Jquery+asp.net后台数据传到前台js进行解析的方法_json

所以在解析后台数据的时候,我们需要根据后台的数据情况,特殊处理和对待。

我这里后台用的是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) {

}

});

或者:

$.each(data.comments, function(i, item) {

$("#info").append(

"

" + item.id + "" +

"

" + item.nickname + "" +

"

" + item.content + "");

});

3、如果是复杂嵌套的话,也是对象了。js中会完全和后台对应。你遍历即可。

现在很多时候,后台返回给前台一般都是用json了。json在js中可以直接解析成对象。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值