MVC3 ajax动作请求:处理答案

时间:2012-11-09 15:07:42

标签: ajax asp.net-mvc

我正在对MVC3操作执行Ajax请求,我想在成功或错误函数中处理JsonResult。 目前行为很奇怪:在操作中遇到断点之前,它会触及错误功能。 请有人帮我,并提示一下吗?

我的观点:

<form id="myForm">
    //fields go here...
    <button id="myButton" onclick="myFunction();">ButtonName</button>
</form>

ajax电话:

function myFunction() {    
if ($('#myForm').valid() == false) {
    return;
}
var data = {
    val1: $("#val1").val(),
    val2: $("#val2").val()
};
var url = "/Controller/Action";
$.ajax({
    url: url,
    type: 'POST',
    dataType: 'json',
    cache: false,
    data: data,
    success: function (data, statusCode, xhr) { 
        alert('1');
        if (data && data.Message) {
            alert(data.Message);
            alert('2');
        }
        alert('3');
    },
    error: function (xhr, errorType, exception) { 
        alert('4');
        var errorMessage = exception || xhr.statusText; 

        alert("There was an error: " + errorMessage);
    }
});
return false; 

}

我的行动:

[HttpPost]
    public ActionResult Action(Class objectName)
    {
        var response = new AjaxResponseViewModel();

            try
            {
                var success = DoSomething(objectName);

                if (success)
                {
                    response.Success = true;
                    response.Message = "Successful!";
                }
                else
                {
                    response.Message = "Error!";
                }
            }
            catch (Exception exception)  
            {  
                response.Success = false;  
                response.Message = exception.Message;   
            }

            return Json(response); 
    }

如果您查看ajax调用,我会直接获得警报#4,然后才会调用该操作为时已晚。不幸的是,异常是空的。在此之后,视图将被关闭。

1 个答案:

答案 0 :(得分:0)

您没有阻止默认的onclick行为。您可以尝试以下方式吗?

onclick="return myFunction()"