创建一个接受 HTML 或其他组件作为参数的视图组件模板/容器

Ric*_*elo 5 asp.net-core razor-pages asp.net-core-viewcomponent view-components

我搜索了很多地方,并没有看到任何与我的想法相似的东西。

假设我想创建一个可重用的容器组件,如卡片、表单或模式,并将其保存为视图组件。我将如何在该主视图组件的“主体”内添加一个新的视图组件,以使其最大程度地可重用?

这里的语法当然只是为了演示这个想法,但例如,像这样:

<vc:parent var1="x" var2="y">
    <vc:child var3="a" var4="b"></vc:child>
    <vc:child var3="c" var4="d"></vc:child>
</vc:parent>
Run Code Online (Sandbox Code Playgroud)

这样的事情有可能吗?

这不一定需要使用视图组件——也许是部分视图?——只要实现重用其他可重用元素的容器的主要目标。

我已经研究过帮助程序,但它们在 ASP.NET Core 中不再可用。

Ric*_*elo 6

所以我想出了如何去做。

我使用了本教程中有关助手的部分内容:Templates With Razor 并对其进行了修改,以便它可以与 ViewComponents 一起使用。

因此,为了使其正常工作,在一个最小的示例中,创建一个 ViewComponent 类,如下所示:

[ViewComponent(Name = "Test")]
public class VCTest : ViewComponent
{
    public IViewComponentResult Invoke(Func<dynamic, object> Content)
    {
        return View(Content);
    }
}
Run Code Online (Sandbox Code Playgroud)

在 cshtml 文件中创建您想要的实际模板,如下所示:

@model Func<dynamic, object>

<div id="SomeTemplateTest">
    @Model(null)
</div>
Run Code Online (Sandbox Code Playgroud)

在这个非常简单的情况下,我只使用 Func 作为模型,因为只有一个参数,但对于更多参数,您只需调用 @Model.funname(null) 而不是 @Model(null)。没什么大不了。

从您的视图调用此组件时,请预先创建您的子元素,如下所示:

@{Func<dynamic, object> children=
    @<div>
        <vc:child var1="a" var2="b"></vc:child>
        <vc:child var1="c" var2="d"></vc:child>
        <vc:child var1="e" var2="f"></vc:child>
    </div>;}
Run Code Online (Sandbox Code Playgroud)

div 只是用来封装所有元素。我还没有找到解决办法,但它没有重大影响。

然后调用父 ViewComponent 标记并相应地传递参数:

<vc:test content="children"></vc:form-test>
Run Code Online (Sandbox Code Playgroud)

就是这样,工作完美。不幸的是我找不到更无缝的方式。但这可以完成工作。

如果有人知道更好的选择,我很想了解更多。