ASP.net分页条怎么做?就是这种“首页 上一页 1 2 3 4下一页 末页”怎么做呢?最好有代码教程,谢谢了

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ASP.net分页条怎么做?就是这种“首页 上一页 1 2 3 4下一页 末页”怎么做呢?最好有代码教程,谢谢了相关的知识,希望对你有一定的参考价值。

参考技术A 最简单的方法是用GridView实现分页,链接为使用示例,你也可以去http://down.51cto.com 下载电子书看看用法,代码太多,我就不写啰

参考资料:http://masxhb.blog.163.com/blog/static/177342060201022591932571/

参考技术B 去下个AspNetPager分页控件吧,这东西没必要自己写,都是现成的。追问

哪里有下的,不过我还是自己想学一下里面的原理

追答

百度下,好像提供源码,可以看下。

本回答被提问者采纳
参考技术C 楼上说的对,aspnetpager分页用的原理是用pagedatasource类进行分页
另外还有用数据库存储过程分页
参考技术D http://www.webdiyer.com/controls/aspnetpager/

下个AspNetPager分页控件很好用的

WPF 实现 DataGrid/ListView 分页控件(转)

 

在WPF中,通常会选用DataGrid/ListView进行数据展示,如果数据量不多,可以直接一个页面显示出来。如果数据量很大,2000条数据,一次性显示在一个页面中,不仅消耗资源,而且用户体验也很糟糕。这篇博客将介绍如何创建一个分页控件。

为了简单起见,这个分页控件目前只有 首页/上一页/下一页/末页/总页数/第几页 等功能。实现思路,首页/上一页/下一页/末页 这四个通过路由事件来实现,在使用时可以使用命令进行绑定,或者直接使用均可。总页数和第几页通过依赖属性来实现,使用时将页数进行绑定显示即可。示例代码如下:

Pager控件:

技术图片
    <UserControl.Resources>
        <Style TargetType="x:Type Button">
            <Setter Property="Width" Value="22"/>
            <Setter Property="Height" Value="22"/>
        </Style>
    </UserControl.Resources>
    <Grid>
        <StackPanel Orientation="Horizontal">
            <Button x:Name="FirstPageButton" Margin="5,0" Click="FirstPageButton_Click">
                <Path Width="7" Height="10" Data="M0,0L0,10 M0,5L6,2 6,8 0,5" Stroke="Black" StrokeThickness="1" Fill="Black" VerticalAlignment="Center" HorizontalAlignment="Center" />
            </Button>
            <Button x:Name="PreviousPageButton" Margin="0,0,5,0" Click="PreviousPageButton_Click">
                <Path Width="8" Height="8" Data="M0,4L8,0 8,8z" Stroke="Black" Fill="Black" VerticalAlignment="Center" HorizontalAlignment="Center" />
            </Button>
            <TextBlock VerticalAlignment="Center">
                <Run Text="第"/>
                <Run x:Name="rCurrent" Text="0"/>
                <Run Text="页"/>
            </TextBlock>
            <Button Margin="5,0" x:Name="NextPageButton" Click="NextPageButton_Click">
                <Path Width="8" Height="8" Data="M0,4L8,0 8,8z" Stroke="Black" Fill="Black" VerticalAlignment="Center" HorizontalAlignment="Center">
                    <Path.RenderTransform>
                        <RotateTransform Angle="180" CenterX="4" CenterY="4" />
                    </Path.RenderTransform>
                </Path>
            </Button>
            <Button Margin="0,0,5,0" x:Name="LastPageButton" Click="LastPageButton_Click">
                <Path x:Name="MainPath" Width="7" Height="10" Data="M0,0L0,10 M0,5 L6,2 6,8 0,5" Stroke="Black" StrokeThickness="1" Fill="Black" VerticalAlignment="Center" HorizontalAlignment="Center">
                    <Path.RenderTransform>
                        <RotateTransform Angle="180" CenterX="3" CenterY="5" />
                    </Path.RenderTransform>
                </Path>
            </Button>
            <TextBlock VerticalAlignment="Center">
                <Run Text="共"/>
                <Run x:Name="rTotal" Text="0"/>
                <Run Text="页"/>
            </TextBlock>
        </StackPanel>     
    </Grid>
技术图片

C#:

技术图片 View Code

在MainWindow中,
XAML:

技术图片
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="*"/>
            <RowDefinition Height="Auto"/>
        </Grid.RowDefinitions>

        <DataGrid Grid.Row="0" ItemsSource="Binding FakeSource" AutoGenerateColumns="False" CanUserAddRows="False">
            <DataGrid.Columns>
                <DataGridTextColumn Header="Item Id" Binding="Binding Id" Width="80"/>
                <DataGridTextColumn Header="Item Name" Binding="Binding ItemName" Width="180"/>
            </DataGrid.Columns>
        </DataGrid>

        <local:Pager TotalPage="Binding TotalPage"
                     CurrentPage="Binding CurrentPage, Mode=TwoWay" 
                     HorizontalAlignment="Center"
                     Grid.Row="1">
            <i:Interaction.Triggers>
                <i:EventTrigger EventName="FirstPage">
                    <i:InvokeCommandAction Command="Binding FirstPageCommand" />
                </i:EventTrigger>
                <i:EventTrigger EventName="PreviousPage">
                    <i:InvokeCommandAction Command="Binding PreviousPageCommand"/>
                </i:EventTrigger>
                <i:EventTrigger EventName="NextPage">
                    <i:InvokeCommandAction Command="Binding NextPageCommand" />
                </i:EventTrigger>
                <i:EventTrigger EventName="LastPage">
                    <i:InvokeCommandAction Command="Binding LastPageCommand"/>
                </i:EventTrigger>
            </i:Interaction.Triggers>
        </local:Pager>
    </Grid>
技术图片

MainViewModel类:

技术图片 View Code

绑定到UI的数据源只是需要显示的数据,不会把所有数据都取出来。当选择显示页数时,只需要将新的数据源附上即可。
技术图片

总结:如果需要对该分页控件进行扩展,例如,增加每页显示条数功能,只需要在Pager控件中增加相应的依赖属性即可。

感谢您的阅读,代码点击这里下载。

以上是关于ASP.net分页条怎么做?就是这种“首页 上一页 1 2 3 4下一页 末页”怎么做呢?最好有代码教程,谢谢了的主要内容,如果未能解决你的问题,请参考以下文章

前台用layui框架实现表格分页,后台用asp.net的问题

前台用layui框架实现表格分页,后台用asp.net的问题

php 查询结果分原网页显示并分页

winform中的DataGridView如何实现分页(C#)

iview 分页改变每页条数时请求两次问题

ASP多值多字段模糊查询分页问题