DataList分页访问FooterTemplate模板里的控件

今天做DataList分页的时候,突然想把分页控件写在FooterTemplate模板里面,弄了很久都访问不到控件,终于发现问题所在,以下是访问FooterTemplate里控件的方法:

<FooterTemplate>
        <div style="width:100%; text-align:right; margin-top:15px;">
                第<asp:Label ID="lblPageIndex" runat="server"></asp:Label>/
                 <asp:Label ID="lblPageCount" runat="server"></asp:Label>页&nbsp;
                 <asp:LinkButton ID="linkFirst" CommandName="First" runat="server">首页</asp:LinkButton>
                 <asp:LinkButton ID="linkPrev" CommandName="Prev" runat="server">上一页</asp:LinkButton>
                 <asp:LinkButton ID="linkNext" CommandName="Next" runat="server">下一页</asp:LinkButton>
                 <asp:LinkButton ID="linkLast" CommandName="Last" runat="server">尾页</asp:LinkButton>
          </div>
 </FooterTemplate>

后台代码:====================================================================

 private int pageCount = 0;
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            ViewState["PageIndex"] = 0;
            DataListBind();
        }
    }

public int Pager
    {
        get { return (int)ViewState["PageIndex"]; }
        set { ViewState["PageIndex"] = value; }
    }

 

private void DataListBind()
    {
        SqlConnection conn = new SqlConnection("data source=.;initial catalog=study;uid=sa;pwd=123456;");
        SqlCommand cmd = new SqlCommand("select * from productinfo", conn);
        SqlDataAdapter sda = new SqlDataAdapter(cmd);
        conn.Close();
        DataSet ds = new DataSet();
        sda.Fill(ds);
        DataList1.DataSource = ds;
        DataList1.DataKeyField = "pid";
        PagedDataSource pds = new PagedDataSource();
        DataView dv = new DataView(ds.Tables[0]);
        pds.DataSource = dv;
        pds.AllowPaging = true;
        pds.PageSize = 8;
        pageCount = pds.PageCount;
        pds.CurrentPageIndex = Pager;
        DataList1.DataSource = pds;

        DataList1.RepeatColumns = 4;
        DataList1.DataBind();

       // 下面的的代码一定要写在DataList1.DataBind();后面,不然会提示:索引超出界限

        Label lblIndex = DataList1.Controls[DataList1.Controls.Count - 1].FindControl("lblPageIndex") as Label;
        Label lblCount = DataList1.Controls[DataList1.Controls.Count - 1].FindControl("lblPageCount") as Label;
        lblIndex.Text = (Pager + 1).ToString();
        lblCount.Text = pds.PageCount.ToString();
    } 

 

protected void DataList1_ItemCommand(object source, DataListCommandEventArgs e)
    {
        Label lblCount = DataList1.Controls[DataList1.Controls.Count - 1].FindControl("lblPageCount") as Label;
        switch (e.CommandName)
        {
            case "First" :
                Pager = 0;
                break;
            case "Prev":
                if (Pager>=1)
                {
                    Pager--;
                }
                 break;
            case "Next":
                 if (Pager < Convert.ToInt32(lblCount.Text)-1)
                 {
                     Pager++;
                 } 
                 break;
            case "Last":
                 Pager = Convert.ToInt32(lblCount.Text)-1;
                break;
        }
        DataListBind();
    }

 

 

转载于:https://www.cnblogs.com/ianunspace/p/3439380.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值