我正在使用 ListView 来显示分页数据:
<asp:ListView ID="listOfItems" runat="server" DataSourceID="ItemsDataSource" EnableModelValidation="True" InsertItemPosition="FirstItem" ItemPlaceholderID="ItemRowContainer">
<LayoutTemplate>
<div class="tablecontainer">
<div class="pagination-top">
<custom:TablePaginationControl ID="TablePaginationControl1" runat="server" ControlID="listOfItems" ShowPageSizeList="true" />
</div>
<table class="list-view">
<tr>
<th class="first-column" width="350px">
<asp:LinkButton ID="SortByName" runat="server" CommandArgument="Name" CommandName="SortMainList" OnCommand="SortItems" Text="<%$ Resources:Name %>"></asp:LinkButton>
</th>
...
</tr>
<tbody>
<tr runat="server" id="ItemRowContainer" />
</tbody>
</table>
</div>
</LayoutTemplate>
...
</asp:ListView>
数据源定义:
<asp:ObjectDataSource ID="ItemsDataSource" runat="server" EnablePaging="True" InsertMethod="AddItems" SelectCountMethod="SelectItemsCount" SelectMethod="SelectItems" TypeName="SHLCentral.TheLibrary.Web.View.DocumentManagementControl, ClientPortal.Web, Version=1.0.0.0, Culture=neutral, PublicKeyToken=cd2852a10d692fb9" UpdateMethod="UpdateItems">
...
</asp:ObjectDataSource>
背后的相关代码是由这两种方法组成的:
public IEnumerable<ListDocumentsResult> SelectItems(
int maximumRows,
int startRowIndex)
{
var results = Controller.ListDocuments(new ListDocumentsRequest());
PropertyInfo sortProperty;
try
{
sortProperty = typeof (ListDocumentsResult).GetProperty((string) ViewState["mainListSortColumn"]);
}
catch
{
sortProperty = null;
}
Func<ListDocumentsResult, object> sortFunction = sortProperty == null
? (Func<ListDocumentsResult, object>) (ldr => ldr.LastUpdatedDate)
: (ldr => sortProperty.GetValue(ldr, new object[0]));
return
(sortProperty == null || !((bool) ViewState["mainListSortAsc"])
? results.OrderByDescending(sortFunction)
: results.OrderBy(sortFunction))
.Skip(startRowIndex)
.Take(maximumRows);
}
protected void SortItems(object sender, CommandEventArgs e)
{
if (e.CommandName == "SortMainList")
{
var sortColumn = (string) e.CommandArgument;
if ((string)ViewState["mainListSortColumn"] == sortColumn)
{
ViewState["mainListSortAsc"] = !(bool)ViewState["mainListSortAsc"];
}
else
{
ViewState["mainListSortAsc"] = true;
ViewState["mainListSortColumn"] = sortColumn;
}
DataBind();
}
}
所以我的意图是:当用户单击LinkButton
“名称”列标题中包含的内容时(为了清楚起见,我只留下一列),SortItems
调用该方法:它将排序的列名称和排序顺序设置为ViewState
,然后重新加载的ListView
使用DataBind
方法。在 的 Select 方法中ObjectDataSource
,我们读取这些ViewState
值并使用它们对数据进行排序。
在所有这些方法上设置断点,当我单击时,我可以看到有以下调用序列LinkButton
:
OnLoad
SortItems
SelectItems
我遇到的问题是,当我到达该SelectItems
方法时,它ViewState
是完全空的(它有 0 个键):如果我在页面的 Load 方法上设置一个断点,我会看到包含所有这些的控件只加载一次。该DataBind
方法似乎没有触发控件的任何加载,它似乎只是触发了SelectItems
控件的新实例的方法(这意味着如果ViewState
我在方法中设置了一个实例字段而不是 using ,SortItems
则该字段为 null进入SelectItems
方法时)。
我确信ViewState
页面上是活动的(例如,我可以ViewState
使用 Firefox 扩展在浏览器端找到键)。
关于页面/控件的生命周期,我不太清楚。有人可以解释一下对我来说是什么吗?