3

再会,

我的 WebMethod 看起来有点像这样......

[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 };
4

1 回答 1

3
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);
    }
}
于 2012-05-08T22:52:22.600 回答