English versionEnglish
博杨计算机有限公司

MvcPager分页控件

Ajax正在加载示例:

本示例演示使用MvcPager的jQuery Ajax分页功能在分页时使用Modal Dialog显示“正在加载...”效果,其中的Modal Dialog效果通过jQuery BlockUI插件实现。

订单编号订单日期顾客编号收货地址
107601997/12/1 0:00:00MAISDRue Joseph-Bens 532
107611997/12/2 0:00:00RATTC2817 Milton Dr.
107621997/12/2 0:00:00FOLKOÅkergatan 24
107631997/12/3 0:00:00FOLIG184, chaussée de Tournai
107641997/12/3 0:00:00ERNSHKirchgasse 6
107651997/12/4 0:00:00QUICKTaucherstraße 10
107661997/12/5 0:00:00OTTIKMehrheimerstr. 369
107671997/12/5 0:00:00SUPRDBoulevard Tirou, 255
107681997/12/8 0:00:00AROUTBrook Farm Stratford St. Mary
107691997/12/8 0:00:00VAFFESmagsloget 45
107701997/12/9 0:00:00HANARRua do Paço, 67
107711997/12/10 0:00:00ERNSHKirchgasse 6
107721997/12/10 0:00:00LEHMSMagazinweg 7
107731997/12/11 0:00:00ERNSHKirchgasse 6
107741997/12/11 0:00:00FOLKOÅkergatan 24
107751997/12/12 0:00:00THECR55 Grizzly Peak Rd.
107761997/12/15 0:00:00ERNSHKirchgasse 6
107771997/12/15 0:00:00GOURLAv. Brasil, 442
107781997/12/16 0:00:00BERGSBerguvsvägen 8
107791997/12/16 0:00:00MORGKHeerstr. 22

jQuery Ajax:

1  2  3  4  5  6  7  8  9  10  ...  下一页  尾页  

MicrosoftAjax:

1  2  3  4  5  6  7  8  9  10  ...  下一页  尾页  
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" 
Inherits="System.Web.Mvc.ViewPage<PagedList<Order>>" %>
<%@ Import Namespace="Webdiyer.WebControls.Mvc"%>
<%@ Import Namespace="MvcPagerSample.Models"%>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
	Ajax正在加载示例
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<script language="javascript" type="text/javascript" 
src="<%=Url.Content("~/Scripts/jquery-1.4.2.min.js") %>"></script>
<script language="javascript" type="text/javascript" 
src="<%=Url.Content("~/Scripts/MicrosoftAjax.js") %>"></script>
<script language="javascript" type="text/javascript" 
src="<%=Url.Content("~/Scripts/MicrosoftMvcAjax.js") %>"></script>
<script language="javascript" type="text/javascript" 
src="<%=Url.Content("~/Scripts/jquery.blockUI.js") %>"></script>
<script language="javascript" type="text/javascript">
    function AjaxStart(){ $.blockUI({ message: '<h2><img 
    src="<%=Url.Content("~/Images/loading.gif") %>" width="16" 
    height="16"/>正在获取数据,请稍候...</h2>' }); }
    function AjaxStop() { $.unblockUI(); }
</script>
    <h2>Ajax正在加载示例:</h2>
    <div>本示例演示使用MvcPager的Ajax分页功能在分页时使用Modal Dialog
    显示“正在加载...”效果,其中的Modal Dialog效果通过jQuery <a 
    href="http://malsup.com/jquery/block" target="_blank">BlockUI插件</a>实现。</div>
    <br />
<%Html.RenderPartial("UCLoading", Model); %>
</asp:Content>    
    
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<PagedList<Order>>" %>
<%@ Import Namespace="Webdiyer.WebControls.Mvc"%>
<%@ Import Namespace="MvcPagerSample.Models"%>
<div id="dvOrders">
<table width="98%">
<tr><th>订单编号</th><th>订单日期</th><th>顾客编号</th><th>收货地址</th></tr>
<%foreach(Order od in Model)
 {
     %>
     <tr><td><%=od.OrderID %></td><td><%=od.OrderDate.ToString() %>
     </td><td><%=od.CustomerID %></td><td><%=od.ShipAddress %></td></tr>
     <%
 } %>
</table>
<p>jQuery Ajax:</p>
<%=Html.AjaxPager(Model, new PagerOptions() { PageIndexParameterName = "id", 
ShowDisabledPagerItems = false,ShowPageIndexBox=true}, 
new AjaxOptions() { UpdateTargetId = "dvOrders",OnBegin="AjaxStart",OnComplete="AjaxStop"})%>
<p>MicrosoftAjax:</p>
<%=Ajax.Pager(Model, new PagerOptions() { PageIndexParameterName = "id", 
ShowDisabledPagerItems = false,ShowPageIndexBox=true,
PageIndexBoxType=PageIndexBoxType.DropDownList,ShowGoButton=false}, 
new AjaxOptions() { UpdateTargetId = "dvOrders",OnBegin="AjaxStart",OnComplete="AjaxStop"})%>
</div>    
    
public ActionResult Loading(int? id)
{
    using (var db = new MvcPagerSampleDataContext())
    {
	PagedList<Order> orders = db.Orders.ToPagedList(id ?? 1, 20);
	if (Request.IsAjaxRequest())
	{
     //休眠3秒,模拟需要花费较长时间才能完成的任务
	    System.Threading.Thread.Sleep(2000);
	    return PartialView("UCLoading", orders);
	}
	return View(orders);
    }
}