使用 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 };

使用 jQuery $.Ajax 将 DTO 传递给 WebMethod 以及一个附加参数

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);
    }
}