Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexanderkrutov/datatables.queryable
.Net library for clever processing of requests from datatables.net jQuery plugin on the server side (ASP.NET, Nancy or any other web server).
https://github.com/alexanderkrutov/datatables.queryable
database-access datatables expression-tree jquery-datatables jquery-datatables-plugin query-builder
Last synced: 16 days ago
JSON representation
.Net library for clever processing of requests from datatables.net jQuery plugin on the server side (ASP.NET, Nancy or any other web server).
- Host: GitHub
- URL: https://github.com/alexanderkrutov/datatables.queryable
- Owner: AlexanderKrutov
- License: mit
- Created: 2016-11-18T21:05:18.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2022-06-22T17:49:59.000Z (over 2 years ago)
- Last Synced: 2024-12-13T22:14:09.121Z (20 days ago)
- Topics: database-access, datatables, expression-tree, jquery-datatables, jquery-datatables-plugin, query-builder
- Language: C#
- Homepage:
- Size: 5.64 MB
- Stars: 51
- Watchers: 8
- Forks: 19
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# DataTables.Queryable
## What is it?
It is a .Net library for clever processing of requests from [datatables.net](https://www.datatables.net/) jQuery plugin on the server side (ASP.NET, [Nancy](https://github.com/NancyFx/Nancy/) or any other web server).The library significantly [reduces boilerplate code](https://github.com/AlexanderKrutov/DataTables.Queryable/wiki/Boilerplate-code-reducing) and helps to avoid writing same logic of parsing requests for different model types.
## Installation [![NuGet Status](http://img.shields.io/nuget/v/DataTables.Queryable.svg?style=flat)](https://www.nuget.org/packages/DataTables.Queryable/)
```
PM> Install-Package DataTables.Queryable
```## How to use it?
```csharp
// ASP.NET action handler inside a controller:
public JsonResult DataTablesRequestAction()
{
// make a DataTablesRequest object from the incoming Http query string
var request = new DataTablesRequest(Request.QueryString);
using (var ctx = new DatabaseContext())
{
// take persons from database, apply the DataTablesRequest filter and paginate
var persons = ctx.Persons.ToPagedList(request);
// push back a result in JSON form applicable for datatables.net
return JsonDataTable(persons);
}
}
```
Need more info? [Welcome to the wiki](https://github.com/AlexanderKrutov/DataTables.Queryable/wiki/).## How it works?
1. DataTables.Queryable parses data from an incoming Http request and extracts related parameters (search text, columns ordering info, page number and number of records per page and etc.);
1. Dynamically builds an expression tree from the request parameters and information about model type `T` using reflection;
1. Filters provided `IQueryable` with the expression tree.
1. Returns query result as a `PagedList` instance (collection of items that represents a single page of extracted data).Take a closer look [what happens inside](https://github.com/AlexanderKrutov/DataTables.Queryable/wiki/How-it-works/).
## Features
* Global search, individual column search, ordering by one or many columns, pagination
* Custom request parameters
* Custom search predicates
* Supports nested properties
* Lazy data loading from provided `IQueryable` (only filtered records will be extracted)
* Compatible with [Entity Framework](https://github.com/aspnet/EntityFramework6)## License
DataTables.Queryable is licensed under [MIT license](LICENSE).