网上的例子都是用datasouce控件绑定listview的,用控件我也成功分页了
可是我要后台自定义数据源再去绑定listview,分页就会点一下没反应,第二下才实现前一下的效果,每次都是这样,无论把绑定的语句放什么位置都是这样,无论<asp:NextPreviousPagerField>还是<asp:TemplatePagerField>自定义按钮都是这样!
哪位高手用过自定义数据源绑listview的,帮忙!!!谢谢!!!!
可是我要后台自定义数据源再去绑定listview,分页就会点一下没反应,第二下才实现前一下的效果,每次都是这样,无论把绑定的语句放什么位置都是这样,无论<asp:NextPreviousPagerField>还是<asp:TemplatePagerField>自定义按钮都是这样!
哪位高手用过自定义数据源绑listview的,帮忙!!!谢谢!!!!
不过不太理解prerender和load的区别,哪位可以解释一下谢谢
DataKeyNames="ProductID">
<layouttemplate>
<table id="Table1" runat="server">
<tr id="Tr1" runat="server">
<td id="Td1" runat="server">
<table id="itemContainer" runat="server" border="0" style="">
</table>
</td>
</tr>
<tr id="Tr2" runat="server">
<td id="Td2" runat="server" style="">
<asp:datapager ID="DataPager1" runat="server">
<fields>
<asp:nextpreviouspagerfield ButtonType="Button" ShowFirstPageButton="True"
ShowNextPageButton="False" ShowPreviousPageButton="False" />
<asp:numericpagerfield />
<asp:nextpreviouspagerfield ButtonType="Button" ShowLastPageButton="True"
ShowNextPageButton="False" ShowPreviousPageButton="False" />
</fields>
</asp:datapager>
</td>
</tr>
</table>
</layouttemplate>
<itemtemplate>
<tr id="Tr3" runat="server" style="">
<td>
ProductID: <asp:Label ID="ProductIDLabel" runat="server"
Text='<%# Eval("ProductID") %>' /></td><td>ProductName: <asp:Label
ID="ProductNameLabel" runat="server" Text='<%# Eval("ProductName") %>' /></td></tr>
</itemtemplate>
</asp:ListView><asp:ListView runat="server" ID="ListView1" DataSourceID="SqlDataSource1"
DataKeyNames="ProductID">
<layouttemplate>
<table id="Table1" runat="server">
<tr id="Tr1" runat="server">
<td id="Td1" runat="server">
<table id="itemContainer" runat="server" border="0" style="">
</table>
</td>
</tr>
<tr id="Tr2" runat="server">
<td id="Td2" runat="server" style="">
<asp:datapager ID="DataPager1" runat="server">
<fields>
<asp:nextpreviouspagerfield ButtonType="Button" ShowFirstPageButton="True"
ShowNextPageButton="False" ShowPreviousPageButton="False" />
<asp:numericpagerfield />
<asp:nextpreviouspagerfield ButtonType="Button" ShowLastPageButton="True"
ShowNextPageButton="False" ShowPreviousPageButton="False" />
</fields>
</asp:datapager>
</td>
</tr>
</table>
</layouttemplate>
<itemtemplate>
<tr id="Tr3" runat="server" style="">
<td>
ProductID: <asp:Label ID="ProductIDLabel" runat="server"
Text='<%# Eval("ProductID") %>' /></td><td>ProductName: <asp:Label
ID="ProductNameLabel" runat="server" Text='<%# Eval("ProductName") %>' /></td></tr>
</itemtemplate>
</asp:ListView>
今天看了一下ListView和DataPager配合做数据分页的教程,感觉很爽很方便,用在自己的项目上面时却出现了问题,具体表现在点击上一页下一页或者数字跳转页面时通常要点两下才能有反应,而且有时候乱跳页我开始测试的代码是这样的:publicpartialclass ListViewTest : System.Web.UI.Page
{
protectedvoid Page_Load(objectif (!Page.IsPostBack)
BindData();
}protectedvoid BindData()
{
DBDataContext db =new DBDataContext();
var ds = db.Category;
ListView1.DataSource = ds;
ListView1.DataBind();
db.Dispose();
}
}
出现如开始提及的问题,找了半天原因也没有找到后来在国外的一个论坛上找到了同病相怜的人,有专家给出了一个解决方案把Page_Load里的数据绑定移到Page_PreRender中,也就是:publicpartialclass ListViewTest : System.Web.UI.Page
{
protectedvoid Page_Load(object//// BindData();
protectedvoid Page_PreRender(object sender, EventArgs e)
{
BindData();
}protectedvoid BindData()
{
DBDataContext db =new DBDataContext();
var ds = db.Category;
ListView1.DataSource = ds;
ListView1.DataBind();
db.Dispose();
}
}
试了一下分页果然正常了难道是Page_Load来的太迟?不得而知另外,还有一种方法同样可行:publicpartialclass ListViewTest : System.Web.UI.Page
{
protectedvoid Page_Load(objectif (!Page.IsPostBack)
BindData();
}protectedvoid Page_PreRender(object//BindData();
protectedvoid ListView1_PagePropertiesChanging(object sender, PagePropertiesChangingEventArgs e)
{
DataPager1.SetPageProperties(e.StartRowIndex, e.MaximumRows, falseprotectedvoid BindData()
{
DBDataContext db =new DBDataContext();
var ds = db.Category;
ListView1.DataSource = ds;
ListView1.DataBind();
db.Dispose();
}
}http://hi.baidu.com/lovedupeng/blog/item/bbbb0d2edec5ec564ec2260a.html
protectedvoid Page_PreRender(object sender, EventArgs e)
{
//把给ListView绑定的代码写在这里
}
注意是 Page_PreRender 事件中
1. Page_Init();
2. Load ViewState;
3. Load Postback data;
4. Page_Load();
5. Handle control events;
6. Page_PreRender();
7. Page_Render();
8. Unload event;
9. Dispose method called;
下面对其中的一些过程作下描述:
1. Page_Init();
这个过程主要是初始化控件,每次页面载入执行这个初始过程,包括第一次和以后的Postback(这里说下Postback,其实就可以简单理解成用户点击SUBMIT按钮之类的,把表单<Form>提交给服务器,这就是一次postback),在这里面可以访问控件,但是这里面的控件值不是我们期待的控件里面的值,他只是一个控件的初始值(默认值),举例: 比如一个TextBox1,我们填入了"哈哈",在点击SUBMIT提交了页面后,在Page_Init()里面,我们访问到的TextBox1.Text不是我们的"哈哈",而是开始的""空字符串,如果TextBox1在我们设计的时候提供了默认值,这里访问到的也就是提供的默认值,为什么呢,这就要看下一个过程了.对应的事件Page.Init2. Load ViewState
这个过程是载入VIEWSTATE和Postback数据,比如我们上面的TextBox1,这时就赋了"哈哈",所以,在Post_Init()对控件赋值是无意义的,它都会在这个过程里被改写,当然第一次页面载入例外,因为没有VIEWSTATE数据。没有对应的事件3.Load Postback data;
上面说了,Postback可以理解成用户提交表单数据,所以这里就是处理表单数据,当然这里要设计到控件的设计,一般情况不会要我们自己处理这个过程,我们暂且略过.没有对应的事件
4. Page_Load();
这个过程也是每次页面载入时一定会执行的,但是注意和Page_Init的区别,上面已经涉及了,这里注意的是一般都会用到Page.IsPostBack,该值指示该页是否正为响应客户端回发而加载,或者它是否正被首次加载和访问。
private void Page_Load(object sender, System.EventArgs e)
{
if(!Page.IsPostBack)
{
//第一次执行的CODE HERE
}
else
{
//用户提交FORM(即Postback)CODE HERE
}//每次这里的都会执行CODE HERE
}对应的事件Page.Load5. Handle control events;
这个过程里,相应具体的控件事件,比如private void ListBox1_SelectedIndexChanged(object sender, System.EventArgs e)事件等等没有对应的事件(我们自己的事件函数都包括在这个过程里比如上面的ListBox1_SelectedIndexChanged)6. Page_PreRender();
预先呈递对象,这里是在向用户程序呈现数据的倒数第二步,提供这个过程的意义,就是在这里能对控件属性等等要呈现给用户的数据进行修改,这也是最后的修改,以前的修改(比如在Page_Init里面)都可能被覆盖.做完这了还会进行一个操作就是保存状态,即SaveViewState.对应的事件时Page.PreRender7. Page_Render();
可以在浏览器里View->Source查看到,每个页面都有一个隐藏的<input>,其中的"__VIEWSTATE"就是服务器写回来的页面状态信息,在这个之前,服务器要呈现页面(也就是构造HTML格式的文件),就是从这个"__VIEWSTATE"里面获取的数据,当然也会注意到,这里有个Page.Render事件,可以添加自己的处理代码,也就是说在这里又可以更改数据,不推荐在这里修改,既然提供了PreRender,就应该在里面做最后的修改,当然这不是必须的,只是推荐!对应的事件Page.Render8. Unload event;
当向服务器请求一个对象的时候,会在内存里生成一个继承页面对象,也就是页面的类,它继承自System.Web.UI.Page.
当页面对象从内存中卸载时发生,将触发该事件.对应的事件Page.Unload9. Dispose method called;
销毁所有的对象.当从内存释放Page时发生,这是生存期的最后阶段。可能第8和9似乎有些模糊,不过我也没怎么搞清楚,待研究!对应的事件Dispose以上就是ASP.NET页面周期的描述。