如何在 blazor 的基础组件中覆盖渲染片段

Dig*_*ers 5 c# razor webassembly blazor blazorise

我正在使用 Blazorise DataGrid,我想制作一个自定义 DataGridColumn,其中 DisplayTemplate 预先设置为模板,但是如果我从 DataGridColumn 派生,我无法弄清楚我应该如何设置 DisplayTemplate。我从这个开始

   @typeparam TItem
   @inherits DataGridColumn<TItem>
Run Code Online (Sandbox Code Playgroud)

但是后来我不知道如何将 DisplayTemplate 渲染片段设置为剃刀片段。

我也尝试过只制作一个包含 DataGridColumn 的组件,并在我的 DataGrid 中引用它,但是无论我将它放在 DataGrid 中的什么位置,该列总是在末尾。

我可能是错误的树,但我有很多实现接口的类,我总是希望为实现该接口的任何类型的任何数据网格中的特定列设置相同的 DisplayTemplate。因此,为此目的创建 DataGridColumn 派生类型似乎是合理的。

Mar*_*rco 1

您可以在代码部分的派生类中填充 DisplayTemplate:

@typeparam TItem
@inherits DataGridColumn<TItem>

@{
    base.BuildRenderTree(__builder);
}


@code { 
    protected override void OnInitialized()
    {
        base.OnInitialized();
        this.DisplayTemplate = (TItem item) => @<CustomDisplayTemplate T="TItem" Item="@item" />;
    }
}
Run Code Online (Sandbox Code Playgroud)

为此,您需要定义一个名为 CustomDisplayTemplate 的单独 Blazor 组件:

@typeparam T
<h2>@Item.ToString()</h2>

@code {
    [Parameter]
    public T Item { get; set; }
}
Run Code Online (Sandbox Code Playgroud)