asp.net-mvc – ASP.Net MVC加载进度指标

我有一个MVC控制器运行一个进程,设置一些View数据,然后在View中将该数据的结果返回给用户.处理时间取决于正在处理的数据量.在进程正在运行的过程中,我需要一个很好的方式在View中显示一个动画的.gif,让用户知道发生了什么.

我已经看过各种AJAX方法和部分视图,但仍然找不到一个很好的方式来实现这一点.我真正希望我可以做的是有一个ActionFilter,它将在OnActionExecuting事件中返回一个视图或部分视图,显示此动画.gif,然后一旦Controller完成处理并返回ViewData,视图或部分视图与实际的视图可以显示数据.

它似乎也可以提供一个很好的异步方式来调用控件在后台执行,然后渲染View.任何帮助将不胜感激.

解决方法

在你的控制器中:
public JsonResult GetSomething(int id)
{
    return Json(service.GetSomething(id));
}

在视图(javascript,使用JQuery):

$('#someLink').click(function()
{
    var action = '<%=Html.ResolveUrl("~/MyController.mvc/GetSomething/")%>' + $('#someId').val() + '?x=' + new Date().getTime();
    $('#loading').show()
    $.getJSON(action,null,function(something) 
    {
        do stuff with something
        $('#loading').hide()
    });
});

请注意,这假设一个路由,其中​​’id’来自动作.动作的’x’参数是在IE中击败积极的缓存.

在视图(标记)中:

<img id="loading" src="images/ajax-loader.gif" alt=""/> 
<!-- use a css stlye to make display:none -->

获取加载器gifs here.

还要注意,你不必这么做Json.如果您愿意,您可以从控制器操作中获取HTML或XML等其他内容.

相关文章

这篇文章主要讲解了“WPF如何实现带筛选功能的DataGrid”,文...
本篇内容介绍了“基于WPF如何实现3D画廊动画效果”的有关知识...
Some samples are below for ASP.Net web form controls:(fr...
问题描述: 对于未定义为 System.String 的列,唯一有效的值...
最近用到了CalendarExtender,结果不知道为什么发生了错位,...
ASP.NET 2.0 page lifecyle ASP.NET 2.0 event sequence cha...