Paging.NET 3.2.10-pre

This is a prerelease version of Paging.NET.
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package Paging.NET --version 3.2.10-pre
                    
NuGet\Install-Package Paging.NET -Version 3.2.10-pre
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Paging.NET" Version="3.2.10-pre" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Paging.NET" Version="3.2.10-pre" />
                    
Directory.Packages.props
<PackageReference Include="Paging.NET" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Paging.NET --version 3.2.10-pre
                    
#r "nuget: Paging.NET, 3.2.10-pre"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Paging.NET@3.2.10-pre
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Paging.NET&version=3.2.10-pre&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=Paging.NET&version=3.2.10-pre&prerelease
                    
Install as a Cake Tool

Paging.NET

Version Downloads Buy Me a Coffee

Paging.NET is a lightweight and flexible library for server-side paging and incremental data loading. Large datasets can be handled more efficiently by retrieving items in smaller, predictable chunks, making data access easier to manage. The library set consists of the following NuGet packages:

  • Paging.NET: Core library containing the main paging models such as PagingInfo and PaginationSet.
  • Paging.Queryable.NET: Extension library providing IQueryable support for paging, sorting, and filtering.
  • Paging.MAUI: Add-on for .NET MAUI moble apps for implementing incremental loading and infinite scrolling scenarios.

Download and Install Paging.NET

This library is available on nuget.org:

Package Version Downlods
Paging.NET Version Downloads
Paging.Queryable.NET Version Downloads
Paging.MAUI Version Downloads

Getting Started

Paging or pagination is the process of splitting a collection into smaller subsets of items in order to improve performance and reduce the amount of data transferred at once. In practice, paging is usually combined with sorting, searching, and filtering.

In Paging.NET, the client sends a paging request as a PagingInfo, and the service responds with a PaginationSet<T>.

How to Use Paging.NET

The core library defines the two main types:

  • PagingInfo is the paging request model. It specifies which page should be loaded, how many items should be returned, and which sorting, search, or filtering options should be applied.
Property Description
CurrentPage The currently selected page.<br/> The default value is 1.
ItemsPerPage Number of items returned per page. <br/>The default value is 0, which means all matching items are returned in a single page.
SortBy Comma-separated sort expression such as "Name Asc" or "Year Desc, Name Asc".
Sorting Dictionary-based sort definition as an alternative to SortBy string.
Reverse Reverses the final sort order.
Search Free-text search value that can be applied by the target data source.
Filter Property-based filter values that can be applied by the target data source.
  • PaginationSet<T> is the paged response model. It contains the items of the current page together with metadata describing the complete result set.
Property Description
CurrentPage The current page number of the returned result. This value is also 1-based.
TotalPages Total number of pages available for the current filter and search criteria.
TotalCount Total number of items matching the current filter and search criteria.
TotalCountUnfiltered Total number of items before filter or search is applied.
Items The items contained in the current page.

The following example shows a simple request using the core models:

var pagingInfo = new PagingInfo
{
    CurrentPage = 1,
    ItemsPerPage = 10,
    SortBy = "Name Asc",
    Search = "Model Desc"
};

A service can then use this request to return a page of Car items. The following example is intentionally kept as pseudo code to illustrate the general flow:

public PaginationSet<Car> GetCars(PagingInfo pagingInfo)
{
    var query = LoadCars();

    // Apply search, filtering, sorting, grouping of data
    // Apply Skip(...).Take(...) for the requested page

    return new PaginationSet<Car>(pagingInfo, pageItems, totalCount, totalCount);
}

If you are working with an IQueryable<T>, the section below shows how Paging.Queryable.NET can perform all necessary steps to create a PaginationSet<T> through CreatePaginationSet<TEntity>(..) extension method.

How to Use Paging.Queryable.NET

Paging.Queryable.NET provides extensions for applying paging directly to an IQueryable<T>. This is useful for backend code working with Entity Framework or any other LINQ provider.

The main entry point is CreatePaginationSet<TEntity>(...). It applies the PagingInfo request to an IQueryable<TEntity> and returns a PaginationSet<TEntity>.

The following example shows how a PaginationSet<Car> can be created directly from an IQueryable<Car>:

IQueryable<Car> queryable = dbContext.Cars;

var pagingInfo = new PagingInfo
{
    CurrentPage = 1,
    ItemsPerPage = 10,
    SortBy = "Year Desc, Name Asc",
    Search = "Model Desc",
    Filter =
    {
        { "Year", 2024 }
    }
};

var paginationSet = pagingInfo.CreatePaginationSet<Car>(queryable);

In this example:

  • Search is applied using the provided search predicate.
  • Filter applies additional property-based constraints.
  • SortBy defines the ordering before paging is applied.
  • The result is returned as a PaginationSet<Car>.
Mapping Entities to DTOs

If entities should be mapped to DTOs, CreatePaginationSet<TEntity, TDto>(...) can be used to apply paging and map the resulting page in one step:

IQueryable<Car> queryable = dbContext.Cars;

var pagingInfo = new PagingInfo
{
    CurrentPage = 1,
    ItemsPerPage = 10,
    SortBy = "Year Desc, Name Asc",
    Search = "Model Desc",
    Filter =
    {
        { "Year", 2024 }
    }
};

var paginationSet = pagingInfo.CreatePaginationSet<Car, CarDto>(
    queryable,
    cars => cars.Select(car => new CarDto
    {
        Id = car.Id,
        Name = car.Name,
        Model = car.Model,
        Price = car.Price,
        Year = car.Year
    }));

This overload returns a PaginationSet<CarDto> instead of PaginationSet<Car>, while preserving the paging metadata. If preferred, sorting can also be defined with the Sorting property instead of SortBy:

var pagingInfo = new PagingInfo
{
    CurrentPage = 1,
    ItemsPerPage = 10,
    Sorting = new Dictionary<string, SortOrder>
    {
        { "Name", SortOrder.Asc },
        { "Year", SortOrder.Desc }
    }
};

The Filter dictionary supports simple property-based filtering. For example:

var pagingInfo = new PagingInfo
{
    Filter = new Dictionary<string, object?>
    {
        { "Name", "Tesla" },
        { "Year", 2024 }
    }
};

How to Use Paging.MAUI

Paging.MAUI provides helpers for incremental loading and infinite scrolling in .NET MAUI apps. The central type is InfiniteScrollCollection<T>. It is typically used together with a PagingInfo instance that keeps track of the next page to load.

The following example is based on the MAUI sample app:

private readonly PagingInfo pagingInfo = new PagingInfo
{
    CurrentPage = 1,
    ItemsPerPage = 30,
};

private PaginationSet<Car>? lastPaginationSet;

public InfiniteScrollCollection<CarDto> Cars { get; } = new InfiniteScrollCollection<CarDto>();

public async Task InitializeAsync(ICarService carService)
{
    this.Cars.OnCanLoadMore = () => !this.lastPaginationSet.StopScroll(this.pagingInfo);
    this.Cars.OnLoadMore = async () =>
    {
        var paginationSet = await carService.GetCarsAsync(this.pagingInfo);
        this.lastPaginationSet = paginationSet;
        this.pagingInfo.CurrentPage++;

        return paginationSet.Items.Select(car => new CarDto
        {
            Id = car.Id,
            Name = car.Name,
            Model = car.Model,
            Price = car.Price,
            Year = car.Year
        });
    };

    await this.Cars.LoadMoreAsync();
}

In XAML, InfiniteScrollBehavior can be attached to a ListView:


<ListView ItemsSource="{Binding Cars}">
    <ListView.Behaviors>
        <paging:InfiniteScrollBehavior
                ItemsSource="{Binding Cars}"
                IsLoadingMore="{Binding IsLoadingMore}"/>
    </ListView.Behaviors>
</ListView>

When the user scrolls to the last item, the next page is loaded automatically as long as OnCanLoadMore returns true.

Contribution

If you find a bug or want to propose a new feature, feel free to create a new issue here. Please use the predefined issue templates when submitting a new issue.

Thank You

Your contribution is valuable! Open source software isn’t just something you can pick up for free — it represents the hard work and dedication of many people who often not even know each other. We sincerely appreciate the time, effort, and dedication shown by everyone who helps keep this plugin going forward.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on Paging.NET:

Package Downloads
Paging.Queryable.NET

Paging.Queryable is a lightweight library for seamless, incremental server-side data loading.

Paging.Forms.NET

Paging.NET is a basic toolkit which provides incremental server-side data loads.

Paging.MAUI

Paging.MAUI is a lightweight library for seamless, incremental server-side data loading.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
4.0.1-pre 179 4/15/2026
3.2.13-pre 151 4/15/2026
3.2.12-pr.3533863989 52 4/15/2026
3.2.11-pre 141 4/15/2026
3.2.10-pre 149 4/15/2026
3.2.9-pr.3533793184 61 4/15/2026
3.2.8-pre 141 4/15/2026
3.2.7-pr.3533780164 49 4/15/2026
3.2.6-pr.3530218190 48 4/15/2026
3.2.5-pr.3530218190 56 4/14/2026
3.2.4-pre 147 4/14/2026
3.1.14-pre 213 1/9/2026
3.1.13-pre 228 1/7/2026
3.1.12-pre 171 1/7/2026
3.1.11-pre 170 1/7/2026
3.1.10-pre 248 12/22/2025
3.1.9 382 12/17/2025
3.1.2-pre 496 12/8/2025
3.1.1-pre 499 12/8/2025
3.0.33 457 5/9/2025
Loading failed

3.2
- Update target framework to net9.0 and net10.0.

3.1
- Add support for nullable reference types.

3.0
- Drop support for Xamarin and .NET Framework.
- Add support for .NET MAUI.

2.2
- Maintenance updates.

2.0
- Add support for .NET standard.

1.0
- Initial release.