将 datatables.net 与服务器端 Blazor 应用程序一起使用

Bug*_*ver 2 blazor blazor-server-side

我正在尝试将 datatables.net 与我的服务器端 Blazor 应用程序一起使用,任何帮助将不胜感激。

我已经尝试了中途提到的代码https://datatables.net/forums/discussion/56389/datatables-with-blazor,但是,我遇到的问题是正在复制某些 UI 元素,例如分页当我在页面之间浏览时。

下面是我的 _Host.cshtml 文件

@page "/"
@namespace MyApplication.Web.Pages
@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers
@{
    Layout = null;
}

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>MyApplication.Web</title>
    <base href="~/" />
    <link rel="stylesheet" href="css/bootstrap/bootstrap.min.css" />
    <link href="css/site.css" rel="stylesheet" />    

    <script src="/lib/jquery/jquery.min.js"></script>
    <script src="/lib/datatables/js/jquery.dataTables.min.js"></script>
    <link href="/lib/datatables/css/jquery.dataTables.min.css" rel="stylesheet" />

</head>
<body>
    <app>
        <component type="typeof(App)" render-mode="ServerPrerendered" />
    </app>

    <div id="blazor-error-ui">
        <environment include="Staging,Production">
            An error has occurred. This application may no longer respond until reloaded.
        </environment>
        <environment include="Development">
            An unhandled exception has occurred. See browser dev tools for details.
        </environment>
        <a href="" class="reload">Reload</a>
        <a class="dismiss"></a>
    </div>   

    <script>
        function AddDataTable(table) {
            $(document).ready(function () {
                $(table).DataTable({
                    "searching": false
                });
            });
        }
    </script>

    <script>
        function RemoveDataTable(table) {
            $(document).ready(function () {
                $(table).DataTable().destroy();
            });
        }
    </script>

    <script src="_framework/blazor.server.js"></script>

</body>
</html>
Run Code Online (Sandbox Code Playgroud)

下面是剃刀组件的代码

using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Components;
using Microsoft.JSInterop;
using MyApplication.Shared.Entities;
using MyApplication.Web.Interfaces;

namespace MyApplication.Web.Pages.Admin
{
    public partial class ListAdministrators
    {
        [Inject]
        public IAdministratorDataService AdministratorDataService { get; set; }

        [Inject]
        public NavigationManager NavigationManager { get; set; }

        public List<Administrator> Administrators { get; set; }

        protected override async Task OnInitializedAsync()
        {
            Administrators = (await AdministratorDataService.GetAll()).ToList();
        }

        protected void NavigateToAddAdministrator()
        {
            NavigationManager.NavigateTo("/Admin/AdministratorEdit");
        }

        protected override async Task OnAfterRenderAsync(bool firstRender)
        {
            await JSRuntime.InvokeAsync<object>("AddDataTable", "#dataTable");
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

需要指出的一件事是,在https://datatables.net/forums/discussion/56389/datatables-with-blazor 上,他们具有我在上面的代码中具有的功能 RemoveDataTable 但是,我不确定这个功能如何在按钮点击之外被调用。

第一次加载 - 一切都很好

在此处输入图片说明

浏览到主页 - 分页 UI 元素仍在显示

在此处输入图片说明

Bug*_*ver 5

我似乎已经用下面的方法解决了重复的 UI 元素问题,但是我很想知道是否有更好的方法,实际上,我确定一定有,所以也许问题应该是下面的方法有多糟糕?

_Host.cshtml 现在添加了以下内容

<script src="~/scripts/JSInterop.js"></script>
<script src="/lib/jquery/jquery.min.js"></script>
<script src="/lib/datatables/js/jquery.dataTables.min.js"></script>
<link href="/lib/datatables/css/jquery.dataTables.min.css" rel="stylesheet" />
Run Code Online (Sandbox Code Playgroud)

创建了一个新组件 DataTable.razor

@inject Microsoft.JSInterop.IJSRuntime JSRuntime;

    <div id="@id">
        @ChildContent
    </div>

@code
{
    [Parameter]
    public bool Searchable { get; set; }

    [Parameter]
    public RenderFragment ChildContent { get; set; }

    private string id { get; set; } = "DataTable-" + Guid.NewGuid().ToString();


    protected override void OnParametersSet()
    {
        StateHasChanged();
        base.OnParametersSet();
    }

    protected async override Task OnAfterRenderAsync(bool firstRender)
    {
        await JSRuntime.InvokeAsync<string>("AddDataTable", new object[] { "#" + id + " table", Searchable });
        await base.OnAfterRenderAsync(firstRender);
    }
}
Run Code Online (Sandbox Code Playgroud)

创建了一个简单的 JS 文件 JSInterop.js

function AddDataTable(table, searching) {    
    $(table).DataTable({
        "searching": searching
    });    
}
Run Code Online (Sandbox Code Playgroud)

然后我在页面上创建数据表时使用以下代码

<DataTable Searchable="true">
        <table class="table">
            <thead>
                <tr>
                    <th>First Name</th>
                    <th>Last Name</th>
                    <th>Access Level</th>
                    <th>Date Added</th>
                    <th></th>
                </tr>
            </thead>
            <tbody>
                @foreach (var administrator in Administrators)
                {
                    <tr>
                        <td>@administrator.Id</td>
                        <td>@administrator.LastName</td>
                        <td>@administrator.AccessLevel.GetDisplayName()</td>
                        <td>@administrator.DateCreated.ToShortDateString()</td>
                        <td>
                            <a href="@($"Admin/EditAdministrator/{administrator.Id}")" class="btn btn-primary table-btn">
                                Edit
                            </a>
                        </td>
                    </tr>
                }
            </tbody>
        </table>
    </DataTable>
Run Code Online (Sandbox Code Playgroud)