我搜索了很多,但未能找到一个有效的解决方案,为什么我的帖子请求没有将它的数据发送到服务器。我可以发送没有数据的请求,我从服务器获取结果,但我无法将数据发送到服务器。我把它缩小到“数据”属性,并假设我只是做错了。谢谢。
客户端
var scriptURL = "default/scripts/serverside/Scripts.aspx";
$.ajax({
type: "POST",
url: baseURL + scriptURL + "/SaveItem",
data: "{}", //works (to return a result)
//data: "{sendData: '" + dataPackage + "'}", //does not work
//data: dataPackage, //does not work
//data: { sendData: dataPackage }, //does not work
//data: { "sendData": dataPackage }, //does not work
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (result) {
de("server result:" +result);
}
});
服务器
[WebMethod]
public static string SaveItem(string sendData)
{
string result = "received: " + sendData;
return result;
}
请帮助,我似乎无法让它工作,并且知道它必须是语法问题......
我发现的类似问题(但没有可行的答案):
答案 0 :(得分:1)
试试这个:
$.ajax({
type: "POST",
url: baseURL + scriptURL + "/SaveItem",
data: $.toJSON({ sendData: dataPackage }),
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (result) {
de("server result:" +result);
}
});
toJSON
会将您的JS对象转换为正确的JSON字符串。您也可以使用JSON.stringify
答案 1 :(得分:0)
试试这个:
var scriptURL = "default/scripts/serverside/Scripts.aspx";
$.ajax({
type: "POST",
url: baseURL + scriptURL + "/SaveItem",
data: {sendData: "string to send" }
dataType: "json",
success: function (result) {
de("server result:" +result);
}
});