ObjectDataSourceを使ったページング
ステートレスなビジネスロジックが一覧データと件数を同時に返すとき
件数を一時的に保持してObjectDataSourceに渡せるようにビジネスロジックを一時的にラップしてあげるといいかもしれない。
GridViewPage.cs
using System.Collections.Generic;
using System.ComponentModel.Composition;
using System.Web.UI.WebControls;namespace Shumisen.Web.Form.IntegrationTest.Data
{
public partial class GridViewPage : System.Web.UI.Page
{
[Import]
public GridViewLogic GridViewLogic { private get; set; }protected void ObjectDataSource1_OnObjectCreating(object sender, ObjectDataSourceEventArgs e)
{
e.ObjectInstance = new LogicAdapter{ GridViewLogic = GridViewLogic};
}public class LogicAdapter
{
private int _count;public GridViewLogic GridViewLogic { private get; set; }
public IEnumerable<Book> GetBooks(int startRowIndex, int maximumRows)
{
return GridViewLogic.GetBooks(startRowIndex, maximumRows, out _count);
}public int GetBookCount()
{
return _count;
}
}
}
}
GridViewPage.cs.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="GridViewPage.aspx.cs" Inherits="Shumisen.Web.Form.IntegrationTest.Data.GridViewPage" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:GridView ID="GridView1" runat="server" AllowPaging="True" AllowSorting="true" AutoGenerateColumns="False"
DataSourceID="ObjectDataSource1">
<Columns>
<asp:BoundField DataField="ASIN" HeaderText="ASIN" SortExpression="ASIN" />
<asp:BoundField DataField="Title" HeaderText="Title" SortExpression="Title" />
</Columns>
</asp:GridView>
<asp:ObjectDataSource ID="ObjectDataSource1" runat="server" SelectMethod="GetBooks"
SelectCountMethod="GetBookCount" TypeName="Shumisen.Web.Form.IntegrationTest.Data.GridViewPage+LogicAdapter"
EnablePaging="true" OnObjectCreating="ObjectDataSource1_OnObjectCreating" />
</div>
</form>
</body>
</html>