使用ajax方法實現分頁也很簡單,主要是兩個,ContentTemplate和Trigger。先把listView扔ContentTemplate裡面。然後在Trigger裡面加入asp:AsyncPostBackTrigger,將ID指向之前的分頁控制項DataPager控制項。具體實現代碼大家可以參考下本文
listview列表實現分頁是非常容易的。ListView分頁是非常簡單的,加上一個DataPager控制項,把ListView的ID賦予就可以了。最開始我就是這麼寫的。(網上有人說這樣是偽分頁?)
<asp:ListView ID="newBlogItems" runat="server" DataSourceID="AccessDataSource1" ViewStateMode="Disabled"> <ItemTemplate> <li class="newBlogItem"> ..... </li> </ItemTemplate> </asp:ListView><asp:DataPager ID="DataPager1" runat="server" PageSize="15" PagedControlID="newBlogItems" ViewStateMode="Disabled"> <Fields> <asp:NextPreviousPagerField ButtonType="Link" ShowFirstPageButton="True" ShowNextPageButton="False" ShowPreviousPageButton="False" /> <asp:NumericPagerField /> <asp:NextPreviousPagerField ButtonType="Link" ShowLastPageButton="True" ShowNextPageButton="False" ShowPreviousPageButton="False" /> </Fields></asp:DataPager>
然而這樣寫完,點擊分頁的效果是重新整理整個頁面,重新整理後頁面跳來跳去當然是不友好的,所以要局部更新頁面,最開始就想到了jquery外掛程式,於是在網上下載了JPAGES這個外掛程式,擺弄了半天也沒弄成,也不知道哪裡有錯誤。。。於是棄坑了,還是ajax吧!。
使用ajax方法就很簡單拉,把大象裝冰箱總共分三步。
1.引入ajax控制項scriptManager,放在form裡。
2.引入ajax控制項UpdatePanel。
3.編輯UpdatePanel內容。
主要是兩個,ContentTemplate和Trigger。先把listView扔ContentTemplate裡面。然後在Trigger裡面加入asp:AsyncPostBackTrigger,將ID指向之前的分頁控制項DataPager控制項,這樣就可以了。代碼如下:
<asp:UpdatePanel runat="server"> <ContentTemplate> <%--資料來源--%><asp:AccessDataSource ID="AccessDataSource1" runat="server" DataFile="C:\storage\users.accdb" SelectCommand="SELECT [userName], [blogTitle], [blogTime], [blogUrl],[statis] FROM [blog] ORDER BY [blogTime] DESC"></asp:AccessDataSource><asp:ListView ID="newBlogItems" runat="server" DataSourceID="AccessDataSource1" ViewStateMode="Disabled"> <ItemTemplate> <li class="newBlogItem">此處略去1000字 </li> </ItemTemplate></asp:ListView><asp:DataPager ID="DataPager1" runat="server" PageSize="15" PagedControlID="newBlogItems" ViewStateMode="Disabled"> <Fields> <asp:NextPreviousPagerField ButtonType="Link" ShowFirstPageButton="True" ShowNextPageButton="False" ShowPreviousPageButton="False" /> <asp:NumericPagerField /> <asp:NextPreviousPagerField ButtonType="Link" ShowLastPageButton="True" ShowNextPageButton="False" ShowPreviousPageButton="False" /> </Fields> </asp:DataPager></ContentTemplate> <Triggers> <asp:AsyncPostBackTrigger ControlID="DataPager1"/> </Triggers> </asp:UpdatePanel>