分页不使用列表视图

时间:2013-05-09 11:40:27

标签: c# asp.net listview

我已经按照教程at codeproject进行了操作,并且偶然发现了一个问题。

我有ListView,列出了我网站的所有当前成员名称:

<asp:ListView ID="lstMembers" runat="server">
    <LayoutTemplate>
        <table>
            <tr>
                <th>Name</th>
            </tr>
            <tr id="itemPlaceholder" runat="server"></tr>
        </table>
    </LayoutTemplate>
    <ItemTemplate>
        <tr>
            <td>
                <%# Eval("MemberName") %>
            </td>
        </tr>
    </ItemTemplate>

</asp:ListView>

下面是DataPager

<asp:DataPager ID="DataPagerProducts" runat="server" PagedControlID="lstMembers"
    PageSize="3" OnPreRender="DataPagerProducts_PreRender">
    <Fields>
        <asp:NumericPagerField />
    </Fields>
</asp:DataPager>

我正在使用以下内容绑定到List(根据教程):

List<Members> member = new List<Members>();

protected void Page_Load(object sender, EventArgs e)
{
    if(Page.IsPostBack) return;

    DisplayMembers();
}

private void DisplayMembers()
{
    const string strSql = "SELECT DISTINCT [id], [memberNickname] FROM vwGetMemberDetails ORDER BY [memberNickname]";
    SqlCommand sqlComm = new SqlCommand(strSql, DataConn.Connect()) { CommandType = CommandType.Text };

    SqlDataReader rdr = sqlComm.ExecuteReader();
    while (rdr.Read())
    {
        member.Add(new Members
            {
                MemberId = rdr["id"],
                MemberName = rdr["memberNickname"]
            });
    }

    rdr.Close();
    DataConn.Disconnect();
}

private class Members
{
    public object MemberId { get; set; }
    public object MemberName { get; set; }
}

protected void DataPagerProducts_PreRender(object sender, EventArgs e)
{
    lstMembers.DataSource = member;
    lstMembers.DataBind();
}

因此,寻呼机目前有2个号码。但是,每次点击2时,List都不会显示任何内容,而Pager会消失。

我通常是Repeater控件的常用工作者,我只是使用这种方法作为假设“更容易”的方式。

谁能告诉我哪里出错?

1 个答案:

答案 0 :(得分:1)

您的变量model未在DataPagerProducts_PreRender中更新,因此它将始终显示已在页面加载中加载的相同数据集。

修改


删除if(Page.IsPostBack) return;或在DisplayMembers()内调用DataPagerProducts_PreRender将为我工作