English versionEnglish
杨涛的个人主页

MvcPager分页控件

ASP.NET MvcPager Ajax事件

本示例演示使用Ajax分页时,如果设置及处理Ajax事件,点击第十页会在服务器端抛出故意设置的异常,从而引发客户端Ajax的OnFailure事件。
注:当使用jQuery" Ajax分页时,AjaxOptions中的OnSuccess属性无效,该属性暂未实现。

订单编号订单日期顾客编号收货地址
107801997/12/16 0:00:00LILASCarrera 52 con Ave. Bolívar #65-98 Llano Largo
107811997/12/17 0:00:00WARTHTorikatu 38
107821997/12/17 0:00:00CACTUCerrito 333
107831997/12/18 0:00:00HANARRua do Paço, 67
107841997/12/18 0:00:00MAGAAVia Ludovico il Moro 22
107851997/12/18 0:00:00GROSR5ª Ave. Los Palos Grandes
107861997/12/19 0:00:00QUEENAlameda dos Canàrios, 891
107871997/12/19 0:00:00LAMAI1 rue Alsace-Lorraine
107881997/12/22 0:00:00QUICKTaucherstraße 10
107891997/12/22 0:00:00FOLIG184, chaussée de Tournai
107901997/12/22 0:00:00GOURLAv. Brasil, 442
107911997/12/23 0:00:00FRANKBerliner Platz 43
107921997/12/23 0:00:00WOLZAul. Filtrowa 68
107931997/12/24 0:00:00AROUTBrook Farm Stratford St. Mary
107941997/12/24 0:00:00QUEDERua da Panificadora, 12
107951997/12/24 0:00:00ERNSHKirchgasse 6
107961997/12/25 0:00:00HILAACarrera 22 con Ave. Carlos Soublette #8-35
107971997/12/25 0:00:00DRACDWalserweg 21
107981997/12/26 0:00:00ISLATGarden House Crowther Way
107991997/12/26 0:00:00KOENEMaubelstr. 90

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">
	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);
    }
}