所有,通过循环jQuery通过传递作为数组对象,并使用C#的WebMethod获取数据出来
我得到我的webmethod在我后面的代码,但我有我的反序列化JSON数据的问题。 我没有很好的参考,但这里是我“米试图做的。我在我的webmethod的代码是不是让我从我的Ajax调用了传递的数据。感谢您的帮助。
$("[id$=rdbSaveAjax1]").click(function() {
var mappedJobRole = new Array();
$(".jobRole").each(function (index) {
var jobRoleIndex = index;
var jobRoleID = $(this).attr('id');
var jobRoleName = $(this).text();
// add all the roleids and rolenames to the job role array.
var roleInfo = {
"roleIndex": jobRoleIndex,
"roleID": jobRoleID,
"roleName": jobRoleName
};
queryStr = { "roleInfo": roleInfo };
mappedJobRole.push(queryStr);
});
$.ajax({
type: "POST",
url: "Apage.aspx/Save_Mapped_Role",
data: "{'savedRole': " + JSON.stringify(mappedJobRole) + "}",
contentType: "application/json; charset=utf-8",
dataType: "json",
async: false,
success: function (data) {
alert("successfully posted data");
},
error: function (data) {
alert("failed posted data");
}
});
});
在我后面的代码我似乎无法获取数据出来 我的等级:
public class MappedRole
{
public int Index { get; set; }
public string RoleID { get; set; }
public string RoleName { get; set; }
}
我的WebMethod:
[WebMethod]
public static bool Save_Mapped_Role(object savedRole)
{
bool success = false;
JavaScriptSerializer js = new JavaScriptSerializer();
IList<MappedRole> role = new JavaScriptSerializer().Deserialize<IList<MappedRole>>savedRole);
int Index = role[0].Index;
string RoleID = role[0].RoleID;
string RoleName = role[0].RoleName;
return success;
}
什么是您的请求和响应JSON的样子,当你使用像萤火虫或IE开发者工具等工具来? – dmck
以及在后面的代码中,我可以看到数据(webmethod),但只是不知道循环访问数据的好方法。我在客户端没有收到任何错误,所以我没有使用萤火虫进行疑难排解。 – MdeVera