zoukankan      html  css  js  c++  java
  • 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:storageusers.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

  • 相关阅读:
    C#中二进制,八进制,十六进制到十进制的相互转换
    Mac装Win10后没有无线网络的处理
    U盘容纳不了大于4G的文件比如ISO文件咋办?
    经典游戏“大富翁4”存档文件修改器Rich4Editor下载
    向C#的选项卡中添加自定义窗体
    C#对二进制文件的特定位置进行读写小结
    抗战剧中最耐看的《我的团长我的团》,最后结尾依然有神剧的影子
    绝大多数人努力程度之低,根本轮不上拼天赋
    ZT:与其怨天尤人,不如全力以赴;若想改变世界,你必须先从改变自己开始!
    java基础学习_多线程02_多线程、设计模式_day24总结
  • 原文地址:https://www.cnblogs.com/NuclearBoy/p/6603079.html
Copyright © 2011-2022 走看看