ASP.NET MVC 2.0 Ajax调用-指定OnSuccess脚本时,不重新隐藏LoadingElementId

问题描述

| 我正在用ASP.NET MVC 2.0编写一个非常简单的Web应用程序,该应用程序用作Web服务的测试接口。各个页面显示一个用户界面,以输入请求消息的参数。参数通过Ajax提交回控制器,该Ajax返回一个局部视图,该局部视图在
标记中包含响应SOAP消息(HTML编码的XML)...

// In controller...
ActionResult WebMethodtest()
{
    return View(new WebMethodModel());
}

[HttpPost]
ActionResult WebMethodTest(WebMethodModel model)
{
    model.Response = MyServiceProxy.WebMethod(model.Request);
    return PartialView(\"SoapResponse\",model.Response);
}

// In view
<% using (Ajax.BeginForm(new AjaxOptions { UpdateTargetId=\"Response\",LoadingElementId=\"Loading\",HttpMethod=\"POST\",OnSuccess=\"prettyPrint\"}))
   { %>
    <!-- varIoUs model bound controls... -->
<% { %>

<div id=\"Loading\" style=\"text-align:center; display:none\">
    <img src=\"../../Content/ajax-loader.gif\" alt=\"loading...\" /><br />
    working...
</div>
不幸的是,在Ajax调用之后返回数据时,Loading div元素没有再次被隐藏,它保持可见状态。有趣的是,如果我删除OnSuccess = \“ prettyPrint \”,它确实可以正确隐藏。我的印象是我的OnSuccess脚本将覆盖认行为,而不是另外执行。我不想丢失prettyPrint,因为它正在使正在显示的XML着色...我如何保持认的加载元素行为以及我自己的OnSuccess挂钩? 干杯!     

解决方法

我通过将OnSuccess脚本修改为此来解决了这个问题:
OnSuccess = \"function() { prettyPrint(); return true; }\"
因此似乎像OnBegin一样,返回false(或除true以外的其他任何值)会取消该操作,尽管在此阶段DOM已经更新,所以您唯一可以取消的就是隐藏Loading元素...似乎没什么用!