使用 jQuery $.Ajax 将 DTO 传递给 WebMethod 以及一个附加参数
本文关键字:一个 参数 WebMethod Ajax jQuery DTO 使用 | 更新日期: 2023-09-27 18:33:30
美好的一天,
我有网络方法,看起来有点像这样...
[WebMethod]
public static string ProcessItem(Item item, ItemStatus status)
{
try
{
item.Process(status);
return "Success!";
}
catch (Exception ex)
{
return ex.Message;
}
}
我有一个jQuery方法,看起来有点像这样...
function Process(dto, status) {
$.ajax({
type: 'POST',
url: 'ProcessPO.aspx/ProcessItem',
data: JSON.stringify(dto) + status',
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function (msg) {
if (msg.d)
alert('success');
},
error: function (xhr, status, errorThrown) {
alert(xhr.responseText);
}
});
}
在 data: 行中,如何连接两者以便正确传入?
dto 是这样定义的...
var dto = { 'item': item };
var d = JSON.Stringify(dto);
d.status = status;
然后在 ajax 调用中
data: d
此外,通过查看您的代码,您可能希望返回 JsonResult。
return Json(new {Success=true}); //Success
return Json(new {Success=false, Message = ex.Message}); //Failure
//if it is a get request
return Json(new {Success=true}, JsonRequestBehavior.AllowGet) //Success
return Json(new {Success=false, Message = ex.Message}, JsonRequestBehavior.AllowGet) //Failure
这将允许您在 javascript 中查看该方法的结果。
success: function(response){
if(response.Success){
alert('Success!');
}else{
alert('Failure! ' + response.Message);
}
}