ASP.NET使用ajax實現分頁局部刷新頁面


    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>

 

查看更多代碼內容,歡迎來我的獨立博客!我的博客本文網址。主頁:www.songshizhao.com

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM