以 asp-for 作为参数的自定义 ViewComponent

2024-06-26

我想把这个包装起来:

<textarea asp-for="@Model.Content" ...>

放入可重用的 ViewComponent 中,其中属性将是参数:

<vc:editor asp-for="@Model.Content" />

我能够将 asp-for 作为参数传递给视图组件:

public class EditorViewComponent : ViewComponent
{
    public IViewComponentResult Invoke(ModelExpression aspFor = null)
    {
        //when debugging, aspFor has correct value
        return View(aspFor);
    }
}

但我无法从组件的角度评估它。这不起作用:

<!-- ViewComponents/Editor/Default.cshtml -->
@model Microsoft.AspNetCore.Mvc.ViewFeatures.ModelExpression
<textarea asp-for="@Model" />

有任何想法吗?


我认为您正在混合 ViewComponents 和 TagHelpers:https://learn.microsoft.com/en-us/aspnet/core/mvc/views/view-components https://learn.microsoft.com/en-us/aspnet/core/mvc/views/view-components

查看组件

视图组件在以下情况下被调用:

@await Component.InvokeAsync("EditorView", @Model.Property);
// or
<vc:[view-component-name]>

尝试以下代码片段:

<vc:editor for="@Model.Content" />

标签帮助程序

标签助手只能像这样调用:

<textarea asp-for="@Model.Content">
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

以 asp-for 作为参数的自定义 ViewComponent 的相关文章

随机推荐