• datapager分页问题(点击两次)


    今天看了一下ListView和DataPager配合做数据分页的教程,感觉很爽很方便,用在自己的项目上面时却出现了问题,具体表现在点击上一页、下一页或者数字跳转页面时通常要点两下才能有反应,而且有时候乱跳页。 

    我开始测试的代码是这样的:

    public partial class ListViewTest : System.Web.UI.Page
    {
        
    protected void Page_Load(object sender, EventArgs e)
        {
            
    if (!Page.IsPostBack)
                BindData();
        }
        
        
    protected void BindData()
        {
            DBDataContext db 
    = new DBDataContext();
            var ds 
    = db.Category;
            ListView1.DataSource 
    = ds;
            ListView1.DataBind();
            db.Dispose();
        }
    }

    出现如开始提及的问题,找了半天原因也没有找到。后来在国外的一个论坛上找到了同病相怜的人,有专家给出了一个解决方案。把Page_Load里的数据绑定移到Page_PreRender中,也就是:

    public partial class ListViewTest : System.Web.UI.Page
    {
        
    protected void Page_Load(object sender, EventArgs e)
        {
            
    //if (!Page.IsPostBack)
            
    //    BindData();
        }

        
    protected void Page_PreRender(object sender, EventArgs e)
        {
            BindData();
        }
        
        
    protected void BindData()
        {
            DBDataContext db 
    = new DBDataContext();
            var ds 
    = db.Category;
            ListView1.DataSource 
    = ds;
            ListView1.DataBind();
            db.Dispose();
        }
    }

    试了一下分页果然正常了。难道是Page_Load来的太迟?不得而知。另外,还有一种方法同样可行:

    public partial class ListViewTest : System.Web.UI.Page
    {
        
    protected void Page_Load(object sender, EventArgs e)
        {
            
    if (!Page.IsPostBack)
                BindData();
        }

        
    protected void Page_PreRender(object sender, EventArgs e)
        {
            
    //BindData();
        }

        
    protected void ListView1_PagePropertiesChanging(object sender, PagePropertiesChangingEventArgs e)
        {
            DataPager1.SetPageProperties(e.StartRowIndex, e.MaximumRows, 
    false);
            BindData();
        }

        
    protected void BindData()
        {
            DBDataContext db 
    = new DBDataContext();
            var ds 
    = db.Category;
            ListView1.DataSource 
    = ds;
            ListView1.DataBind();
            db.Dispose();
        }
    }
  • 相关阅读:
    仅坚持了9天:京东今日宣布暂停火车票代购业务
    Highcharts JS——制作图表的纯js类库
    eclipse插件——php工具集成
    如何新增histats计数器到自己的 blog
    C#写入文本txt
    我怎么感觉js快无敌了~
    马云卸任演讲全文
    添加好玩的honehoneclock到自己的blog
    C#获取日期的年月日时分秒
    js闭包
  • 原文地址:https://www.cnblogs.com/wwb0111/p/3098925.html
Copyright © 2020-2023  润新知