MvcPager分页控件
ASP.NET MvcPager Ajax事件
本示例演示使用Ajax分页时,如果设置及处理Ajax事件,点击第十页会在服务器端抛出故意设置的异常,从而引发客户端Ajax的OnFailure事件。
注:当使用jQuery" Ajax分页时,AjaxOptions中的OnSuccess属性无效,该属性暂未实现。
注:当使用jQuery" Ajax分页时,AjaxOptions中的OnSuccess属性无效,该属性暂未实现。
| 订单编号 | 订单日期 | 顾客编号 | 收货地址 |
|---|---|---|---|
| 10860 | 1998/1/29 0:00:00 | FRANR | 54, rue Royale |
| 10861 | 1998/1/30 0:00:00 | WHITC | 1029 - 12th Ave. S. |
| 10862 | 1998/1/30 0:00:00 | LEHMS | Magazinweg 7 |
| 10863 | 1998/2/2 0:00:00 | HILAA | Carrera 22 con Ave. Carlos Soublette #8-35 |
| 10864 | 1998/2/2 0:00:00 | AROUT | Brook Farm Stratford St. Mary |
| 10865 | 1998/2/2 0:00:00 | QUICK | Taucherstraße 10 |
| 10866 | 1998/2/3 0:00:00 | BERGS | Berguvsvägen 8 |
| 10867 | 1998/2/3 0:00:00 | LONEP | 89 Chiaroscuro Rd. |
| 10868 | 1998/2/4 0:00:00 | QUEEN | Alameda dos Canàrios, 891 |
| 10869 | 1998/2/4 0:00:00 | SEVES | 90 Wadhurst Rd. |
| 10870 | 1998/2/4 0:00:00 | WOLZA | ul. Filtrowa 68 |
| 10871 | 1998/2/5 0:00:00 | BONAP | 12, rue des Bouchers |
| 10872 | 1998/2/5 0:00:00 | GODOS | C/ Romero, 33 |
| 10873 | 1998/2/6 0:00:00 | WILMK | Keskuskatu 45 |
| 10874 | 1998/2/6 0:00:00 | GODOS | C/ Romero, 33 |
| 10875 | 1998/2/6 0:00:00 | BERGS | Berguvsvägen 8 |
| 10876 | 1998/2/9 0:00:00 | BONAP | 12, rue des Bouchers |
| 10877 | 1998/2/9 0:00:00 | RICAR | Av. Copacabana, 267 |
| 10878 | 1998/2/10 0:00:00 | QUICK | Taucherstraße 10 |
| 10879 | 1998/2/10 0:00:00 | WILMK | Keskuskatu 45 |
jQuery Ajax:
MicrosoftAjax:
<%@ 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">
ASP.NET MvcPager 分页示例—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>
<h2>Ajax事件</h2>
<div>本示例演示使用Ajax分页时,如果设置及处理Ajax事件,
点击第十页会在服务器端抛出故意设置的异常,从而引发客户端Ajax的OnFailure事件。
<br /><span style="color:red">注:当使用jQuery" Ajax分页时,
AjaxOptions中的OnSuccess属性无效,该属性暂未实现。</span></div><br />
<%Html.RenderPartial("UCAjaxEvents", 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",
ShowPageIndexBox = true, PageIndexBoxType = PageIndexBoxType.DropDownList,
ShowGoButton = false }, new AjaxOptions() { UpdateTargetId = "dvOrders",
OnBegin = "function(){alert('Ajax OnBegin 事件被引发');}",
OnComplete = "function(){alert('Ajax OnComplete 事件被引发');}",
OnFailure = "function(){alert('Ajax OnFailure 事件被引发');}" })%>
<p>MicrosoftAjax:</p>
<%=Ajax.Pager(Model, new PagerOptions() { PageIndexParameterName = "id",
ShowPageIndexBox = true, PageIndexBoxType = PageIndexBoxType.DropDownList,
ShowGoButton = false }, new AjaxOptions() { UpdateTargetId = "dvOrders",
OnBegin = "function(){alert('Ajax OnBegin 事件被引发');}",
OnComplete = "function(){alert('Ajax OnComplete 事件被引发');}",
OnSuccess="function(){alert('OnSuccess事件被引发');}",
OnFailure = "function(){alert('Ajax OnFailure 事件被引发');}" })%>
</div>
public ActionResult AjaxEvents(int? id)
{
using (var db = new MvcPagerSampleDataContext())
{
if (id.HasValue&&id.Value == 10) //点第十页时故意抛出异常
throw new Exception("为测试而抛出的异常");
PagedList<Order> orders = db.Orders.ToPagedList(id ?? 1, 20);
if (Request.IsAjaxRequest())
return PartialView("UCAjaxEvents", orders);
return View(orders);
}
}
