0

我已经按照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<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控件的常客,并且仅将这种方法用作假设的“更简单”的方法。

谁能告诉我哪里出错了?

4

1 回答 1

1

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

编辑


在里面删除if(Page.IsPostBack) return;或调用对我有用DisplayMembers()DataPagerProducts_PreRender

于 2013-05-09T12:03:30.653 回答