我正在尝试创建一个自定义控件,该控件呈现可以选择日期的日历。我需要将一个ITemplate传递给控件的能力,该控件将为每天呈现。白天是由一个复述者呈现的。
由于目前没有允许绑定到ITemplate的现有控件(或者使用ITemplate与集合以外的任何东西),如何从controlProperty轻松地呈现ITemplate?我更希望有某种只呈现ITemplate的控件,这样就可以在其他地方重用它。
部分控制标记:
<!-- ... -->
<dot:Repeater ID="DaysRepeater" DataSource="{value: Days}" class="list-group list-group-flush calendar-grid">
<ItemTemplate>
<div class="{{value: "calendar-day calendar-day-" + DayOfWeekIndex }}">
<dot:LinkButton ID="DayButton" class="{{value: "list-group-item list-group-item-action " + (Selected ? "active calendar-day-btn" : "calendar-day-btn") }}"
Click="{controlCommand: SelectDate(_this.Date)}">
{{value: DayText}}
<!-- RENDER TEMPLATE HERE -->
</dot:LinkButton>
</div>
</ItemTemplate>
</dot:Repeater>代码隐藏中的ItemTemplate:
[MarkupOptions(AllowBinding = false, MappingMode = MappingMode.InnerElement, Required = false)]
[ConstantDataContextChange(typeof(ICollection<CalendarDayModel>)), CollectionElementDataContextChange(1)]
public ITemplate ItemTemplate
{
get { return (ITemplate)GetValue(ItemTemplateProperty)!; }
set { SetValue(ItemTemplateProperty, value); }
}
public static readonly DotvvmProperty ItemTemplateProperty =
DotvvmProperty.Register<ITemplate, Calendar>(t => t.ItemTemplate);控件的示例用法:
<cc:Calendar DataContext="{value: CalendarViewModel}" MultiSelect="true">
<ItemTemplate>
Selected: {{value: Selected}}
</ItemTemplate>
</cc:Calendar>发布于 2021-02-11 09:33:47
不幸的是,我们在DotVVM中没有任何可以绑定模板并将其呈现的控件。但是,您可以执行以下操作:
Repeater模板中的
PlaceHolder控件<dot:Repeater ID="DaysRepeater" DataSource="{value: Days}" class="list-group list-group-flush calendar-grid">
<ItemTemplate>
<div class="{{value: "calendar-day calendar-day-" + DayOfWeekIndex}}">
<dot:LinkButton ID="DayButton" class="{{value: "list-group-item list-group-item-action " + (Selected ? "active calendar-day-btn" : "calendar-day-btn") }}"
Click="{controlCommand: SelectDate(_this.Date)}">
{{value: DayText}}
<dot:PlaceHolder ID="TemplateHost" />
</dot:LinkButton>
</div>
</ItemTemplate>
</dot:Repeater>Repeater模板替换为您自己的模板,该模板将首先呈现原始模板,然后找到占位符,并将内部模板放入:protected override void OnInit(IDotvvmRequestContext context)
{
var repeater = (Repeater)FindControlInContainer("DaysRepeater");
repeater!.ItemTemplate = new TemplateWrapper(ItemTemplate, repeater!.ItemTemplate);
base.OnInit(context);
}
class TemplateWrapper : ITemplate
{
private readonly ITemplate innerTemplate;
private readonly ITemplate repeaterTemplate;
public TemplateWrapper(ITemplate innerTemplate, ITemplate repeaterTemplate)
{
this.innerTemplate = innerTemplate;
this.repeaterTemplate = repeaterTemplate;
}
public void BuildContent(IDotvvmRequestContext context, DotvvmControl container)
{
repeaterTemplate.BuildContent(context, container);
var placeholder = container.FindControlInContainer("TemplateHost");
innerTemplate.BuildContent(context, placeholder!);
}
}https://stackoverflow.com/questions/65978525
复制相似问题