Logo

dev-resources.site

for different kinds of informations.

ASP.NET8 using DataTables.net โ€“ Part3 โ€“ State saving

Published at
11/7/2024
Categories
aspnet
datatables
Author
markpelf
Categories
2 categories in total
aspnet
open
datatables
open
Author
8 person written this
markpelf
open
ASP.NET8 using DataTables.net โ€“ Part3 โ€“ State saving

A practical guide to using jQuery DataTables.net component in Asp.Net 8 MVC application.

Abstract: A practical guide to building an Asp.Net 8 MVC application that uses jQuery component DataTables.net. This is a continuation of article Part2.

1 ASP.NET8 using jQuery DataTables.net

I was evaluating the jQuery DataTables.net component [1] for usage in ASP.NET8 projects and created several prototype (proof-of-concept) applications that are presented in these articles.

1.1 Articles in this series

Articles in this series are:

  • ASP.NET8 using DataTables.net โ€“ Part1 โ€“ Foundation
  • ASP.NET8 using DataTables.net โ€“ Part2 โ€“ Action buttons
  • ASP.NET8 using DataTables.net โ€“ Part3 โ€“ State saving
  • ASP.NET8 using DataTables.net โ€“ Part4 โ€“ Multilingual
  • ASP.NET8 using DataTables.net โ€“ Part5 โ€“ Passing additional parameters in AJAX
  • ASP.NET8 using DataTables.net โ€“ Part6 โ€“ Returning additional parameters in AJAX
  • ASP.NET8 using DataTables.net โ€“ Part7 โ€“ Buttons regular
  • ASP.NET8 using DataTables.net โ€“ Part8 โ€“ Select rows
  • ASP.NET8 using DataTables.net โ€“ Part9 โ€“ Advanced Filters

2 Final result

The goal of this article is to create a proof-of-concept application that demos DataTables.net component state saving. Let us present the result of this article. Here on this screen, you see the example app in a certain โ€œstateโ€, that is filter โ€œmarkโ€ is applied, and sort is done by โ€œFamily nameโ€ descending.

Users often ask that when they navigate away from the page and then return, they are in the same state they left. That is shown in this article, you can in this application navigate away and come back, and the DataTables component will be in the same state as when you left.

The topic of this article is to show how to implement it. It is quite easy, that is a feature included in the component, and the state is saved on the client side, inside browser storage.

3 Client-side DataTables.net component

Here I will just show what the ASP.NET view using DataTables component looks like.

<!-- Employees.cshtml -->
<partial name="_LoadingDatatablesJsAndCss" />

@{
    <div class="text-center">
        <h3 class="display-4">Employees table</h3>
    </div>

    <!-- Here is our table HTML element defined. JavaScript library Datatables
    will do all the magic to turn it into interactive component -->
    <table id="EmployeesTable01" class="table table-striped table-bordered ">
    </table>

}


<script>
    // Datatables script initialization=========================================
    // we used defer attribute on jQuery so it might not be available at this point
    // so we go for vanilla JS event

    document.addEventListener("DOMContentLoaded", InitializeDatatable);

    function InitializeDatatable() {
        $("#EmployeesTable01").dataTable({
            //processing-Feature control the processing indicator.
            processing: true,
            //paging-Enable or disable table pagination.
            paging: true,
            //info-Feature control table information display field
            info: true,
            //ordering-Feature control ordering (sorting) abilities in DataTables.
            ordering: true,
            //searching-Feature control search (filtering) abilities
            searching: true,
            //search.return-Enable / disable DataTables' search on return.
            search: {
                return: true
            },
            //autoWidth-Feature control DataTables' smart column width handling.
            autoWidth: true,
            //lengthMenu-Change the options in the page length select list.
            lengthMenu: [10, 15, 25, 50, 100],
            //pageLength-Change the initial page length (number of rows per page)
            pageLength: 10,

            //order-Initial order (sort) to apply to the table.
            order: [[1, 'asc']],

            //serverSide-Feature control DataTables' server-side processing mode.
            serverSide: true,

            //stateSave-State saving - restore table state on page reload.
            stateSave: true,
            //stateDuration-Saved state validity duration.
            //-1 sessionStorage will be used, while for 0 or greater localStorage will be used.
            stateDuration: -1,

            //Load data for the table's content from an Ajax source.
            ajax: {
                "url": "@Url.Action("EmployeesDT", "Home")",
                "type": "POST",
                "datatype": "json"
            },

            //Set column specific initialisation properties
            columns: [
                //name-Set a descriptive name for a column
                //data-Set the data source for the column from the rows data object / array
                //title-Set the column title
                //orderable-Enable or disable ordering on this column
                //searchable-Enable or disable search on the data in this column
                //type-Set the column type - used for filtering and sorting string processing
                //visible-Enable or disable the display of this column.
                //width-Column width assignment.
                //render-Render (process) the data for use in the table.
                //className-Class to assign to each cell in the column.

                {   //0
                    name: 'id',
                    data: 'id',
                    title: "Employee Id",
                    orderable: true,
                    searchable: false,
                    type: 'num',
                    visible: true
                },
                {
                    //1
                    name: 'givenName',
                    data: "givenName",
                    title: "Given Name",
                    orderable: true,
                    searchable: true,
                    type: 'string',
                    visible: true
                },
                {
                    //2
                    name: 'familyName',
                    data: "familyName",
                    title: "Family Name",
                    orderable: true,
                    searchable: true,
                    type: 'string',
                    visible: true
                },
                {
                    //3
                    name: 'town',
                    data: "town",
                    title: "Town",
                    orderable: true,
                    searchable: true,
                    type: 'string',
                    visible: true
                },
                {
                    //4
                    name: 'country',
                    data: "country",
                    title: "Country",
                    orderable: true,
                    searchable: true,
                    type: 'string',
                    visible: true
                },
                {
                    //5
                    name: 'email',
                    data: "email",
                    title: "Email",
                    orderable: true,
                    searchable: true,
                    type: 'string',
                    visible: true,
                    width: "150px",
                    className: 'text-center '
                },
                {
                    //6
                    name: 'phoneNo',
                    data: "phoneNo",
                    title: "Phone Number",
                    orderable: false,
                    searchable: true,
                    type: 'string',
                    visible: true
                },
                {
                    //7
                    name: 'actions',
                    data: "actions",
                    title: "Actions",
                    orderable: false,
                    searchable: false,
                    type: 'string',
                    visible: true,
                    render: renderActions
                },
                {
                    //8
                    name: 'urlForEdit',
                    data: "urlForEdit",
                    title: "urlForEdit",
                    orderable: false,
                    searchable: false,
                    type: 'string',
                    visible: false
                }
            ]
        });

        function renderActions(data, type, row, meta) {
            //for Edit button we get Url from the table data
            let html1 =
                '<a class="btn btn-info" href="' +
                row.urlForEdit + '">Edit</a>';

            //for Info button we create Url in JavaScript
            let infoUrl = "@Url.Action("EmployeeInfo", "Home")" +
                "?EmployeeId=" + row.id;
            let html2 =
                '<a class="btn btn-info"  style="margin-left: 10px" href="' +
                infoUrl + '">Info</a>';

            return html1 + html2;
        }
    }
</script>


Enter fullscreen mode Exit fullscreen mode

Note properties โ€œstateSaveโ€ and โ€œstateDurationโ€ in the configuration of DataTables component. They just need to be activated to use that functionality.

  • Property stateSave - State saving - restore table state on page reload.
  • Property stateDuration - Saved state validity duration. If set to -1 sessionStorage will be used, while for 0 or greater localStorage will be used.

More about these properties can be found in the manual at [1]. The application here is just a proof of concept for ASP.NET environment.

4 How Save State works

It is always interesting to see how things work from the inside. With Chrome DevTools we can have a peek into browser Session storage.

You can see that the DataTables.net component has created a key for itself, for that particular URL, since there can be several pages with DataTables.net component and each needs to preserve its own state. You can see that the state is saved in a big JSON, and there are our search phrase โ€œmarkโ€ and โ€œorder by column 2, descendingโ€ setting.

5 Conclusion

The full example code project can be downloaded at GitHub [99].

6 References

[1] https://datatables.net/

[99] https://github.com/MarkPelf/ASPNET8UsingDataTablesNet

aspnet Article's
30 articles in total
Favicon
The Future of ASP.NET: What to Expect
Favicon
DevExpress - Enhancing ASP.NET Web Forms with the ASPxGridView Control
Favicon
Advanced Search in .NET with Elasticsearch(Full Video)
Favicon
Introducing Brick SaaS Starter Kit - Launch SaaS Products Faster
Favicon
Using server sent events in ASP.NET
Favicon
Important Links
Favicon
Serverless OAuth2/OIDC server with OpenIddict 6 and RDS Aurora v2
Favicon
Learning in Reverse: How I Would Learn ASP. Net Core and Entity Framework If I Could Go Back In Time
Favicon
Dependency injection validation error in ASP.NET Core projects
Favicon
Agrupamiento de datos de una lista usando LINQ en C#
Favicon
Asp .Net: Create a Simple 'Web User Control'
Favicon
[ASP.NET] ๅฆ‚ไฝ•ๅฐŽๅ‘ๅˆฐ้Œฏ่ชค้ ้ข
Favicon
DevExpress - Simplifying Server-to-Client Data Transfer with ASPxCallback JSProperties
Favicon
Asp.net
Favicon
[ASP.NET] ่จญ็ฝฎ่ˆ‡ๅ–ๅพ— Web.config ่‡ชๅฎš็พฉ่ณ‡ๆ–™
Favicon
How to Hire Dedicated .NET Developers
Favicon
Permission-Based Authorization in ASP.NET Core: A Step-by-Step Guide
Favicon
Permission-Based Authorization in ASP.NET Core: A Step-by-Step Guide
Favicon
Dependency Container and Services Lifetimes (ะะฐ ั€ัƒััะบะพะผ)
Favicon
Containerize ASP.NET Core API, Entity Framework with SQL Server, Let's Encrypt, Docker, and Nginx (Part 1)
Favicon
differences of Transient and scoped in ASP NET
Favicon
ASP.NET8 using DataTables.net โ€“ Part6 โ€“ Returning additional parameters in AJAX
Favicon
ASP.NET8 using DataTables.net โ€“ Part4 โ€“ Multilingual
Favicon
ASP.NET8 using DataTables.net โ€“ Part8 โ€“ Select rows
Favicon
ASP.NET8 using DataTables.net โ€“ Part3 โ€“ State saving
Favicon
ASP.NET8 using DataTables.net โ€“ Part7 โ€“ Buttons regular
Favicon
ASP.NET8 using DataTables.net โ€“ Part5 โ€“ Passing additional parameters in AJAX
Favicon
ASP.NET8 using DataTables.net โ€“ Part9 โ€“ Advanced Filters
Favicon
ASP.NET8 using DataTables.net โ€“ Part2 โ€“ Action buttons
Favicon
ASP.NET 8 โ€“ Multilingual Application with single Resx file โ€“ Part 3 โ€“ Forms Validation Strings

Featured ones: