我在asp.net第一次使用JSON
我有像我这样的WebMethod
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public static string Vo_Get(string Action,int ID)
{
Product p= new Product();
DataSet ds= new DataSet();
p.Action = Action;
p.ID= ID;
ds= VoGet_Get(obj);
**string jsonVesselDetails = JsonConvert.SerializeObject(ds, Formatting.None);
return jsonVesselDetails;**
}
这里我得到了我的结果
[
{
"Pinky": 1,
"Ponky": "Breakwater Dockk",
},
{
"Pinky": 2,
"Ponky": "Watson Island Dock",
},
但是,当我尝试使用Ajax调用并附加到表时,如果我尝试使用结果绑定并且如果我尝试使用result.data绑定则给出Unexpexted Token U
最后我发现问题在于序列化,
我的Ajax调用是
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "Voyage.aspx/Vo_Get",
data: "{'Action':'Get','ID':'68'}",
dataType: "json",
success: function (data) {
try {
alert("getdata! success" );
Get(data);
} catch (ex) {
alert(ex);
}
},
error: function (msg) {
alert("err: " + error);
}
});
和
答案 0 :(得分:0)
我不知道GetVessels期待什么,但尝试:
GetVessels(data.d);
即。传递实际数据而不是整个响应对象。
答案 1 :(得分:0)
也许您在成功函数中使用相同的变量data
。
尝试使用以下内容,
success: function (result) {
try {
alert("getdata! success" );
GetVessels(result);
//Rebuild the table
//BuildVesselTaggerInfo();
} catch (ex) {
alert(ex);
}
},
请注意,我已从数据更改为结果。
答案 2 :(得分:0)
首先验证您的JSON
方法所期望的GetVessles
或数组结构类型。
您可以通过直接提供VoyageVessel_Get
方法的JSON响应或手动构建它来实现。即。
var data= [
{
"TerminalID": 1,
"TerminalName": "Breakwater Dockk",
"PortID": 1,
"PortName": "Swire Pacific Offshore",
"Column1": "08/03/13",
"Column2": "16/03/13",
"ServiceID": 2
},
{
"TerminalID": 2,
"TerminalName": "Watson Island Dock",
"PortID": 2,
"PortName": "Keppel Offshore",
"Column1": "20/03/13",
"Column2": "23/03/13",
"ServiceID": 2
}];
GetVessels(data);
查看您的GetVessels
是否适用于此对象。如果没有,那么找出它需要什么样的结构(只有你能做到),并构建它。
其次,您无法直接访问:success
中ASP.NET Web-Service
的回复。
像这样访问它:
success: function (data) {
var jsonData= data.d;
GetVessels(jsonData);
}
如果您的对象由datetime字段组成,请尝试在Serialization
中指定DateFormathandling,即
JsonSerializerSettings microsoftDateFormatSettings = new JsonSerializerSettings
{
DateFormatHandling = DateFormatHandling.MicrosoftDateFormat
};
string serializedObject= Newtonsoft.Json
.JsonConvert
.SerializeObject(dsVoyages, microsoftDateFormatSettings);