【发布时间】:2011-05-29 14:37:06
【问题描述】:
所以这是我的问题。我正在使用 Jquery 的 $.ajax 将一系列值传递回 Web 方法。 Web 方法获取值,创建一个对象,然后将其作为 json 发送回调用页面。收到回复后,我将无法访问回复并显示其值。
谁能解释我需要做什么才能完成这项工作?
jquery 脚本:
$(document).ready(function() {
$("#create").click(function() {
var name = $('#name').val();
var company = $('#company').val();
var location = $('#location').val();
var phonenumber = $('#phonenumber').val();
var country = $('#country').val();
$.ajax({
type: "POST",
url: "WebService.asmx/MakeEmployee",
data: "{name:'" + name +
"',company:'" + company +
"',location:'" + location +
"',phonenumber:'" + phonenumber +
"',country:'" + country +
"'}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(msg) {
AjaxSucceeded(msg.d);
}
});
});
function AjaxSucceeded(data) {
//var item = jQuery.parseJSON(data) // this doesn't work for me.
$("#response").html(
"<ul><li> " + data.Name +
"</li><li> " + data.Company +
"</li><li> " + data.Address +
"</li><li> " + data.Phone +
"</li><li> " + data.Country +
"</ul> "
);
};
});
网络方法:
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public string MakeEmployee(string name, string company,
string location, string phoneNumber, string country)
{
Employee e = new Employee(name, company, location, phoneNumber, country);
return new JavaScriptSerializer().Serialize(e);
}
我得到的回应是:
{"d":"\"Name\":\"bob\",
\"Company\":\"google\",
\"Address\":\"home\",
\"Phone\":\"123\",
\"Country\":\"usa\"}"}
这是我认为我应该回来的:
{"Name":"bob",
"Company":"google",
"Address":"home",
"Phone":"123",
"Country":"usa"}
页面再次呈现后我得到的错误是:
•undefined
•undefined
•undefined
•undefined
•undefined
【问题讨论】:
-
我并没有像你在这里那样做,但我会尝试摆脱你对
JavaScriptSerializer的使用。只需返回您的Employee类,框架就会为您将其转换为 Json。 -
你是对的。 JavaScriptSerializer() 部分对我的 json 响应做了一些时髦的事情。感谢您的提示!