2

我有这个 ScrollViewer:

<ScrollViewer x:Name="myScrollViewer">
  <ItemsControl x:Name="myItemsControl" ItemTemplateSelector="{DynamicResource myItemtemplateSelector}" ItemsPanel="{StaticResource myItemsPanel}" />
</ScrollViewer>

ItemsControl我用一个具有一个布尔参数的类填充。如果是真的,我想打电话给一个ItemTemplateSelector;还有一个是假的。

我正在尝试这样的事情:

<ItemsControl x:Name="myItemsControl" ItemsPanel="{StaticResource myItemsPanel}">
  <ItemsControl.ItemTemplate>
    <DataTemplate>
      <ContentControl>
        <ContentControl.Style>
          <Style TargetType="{x:Type ContentControl}">
            <Style.Triggers>
              <DataTrigger Binding="{Binding Path=myBoolean}" Value="False">
                <Setter Property="ContentTemplate" Value="{DynamicResource SubdisciplineDataTemplateSelector}" />
              </DataTrigger>
              <DataTrigger Binding="{Binding Path=myBoolean}" Value="True">
                <Setter Property="ContentTemplate" Value="{DynamicResource SubdisciplineDataTemplateSelector2}" />
              </DataTrigger>
            </Style.Triggers>
          </Style>
        </ContentControl.Style>
      </ContentControl>
    </DataTemplate>
  </ItemsControl.ItemTemplate>
</ItemsControl>

这是正确的方法吗?

4

1 回答 1

4

好吧,不,这条线是错误的:

<Setter Property="ContentTemplate" Value="{DynamicResource SubdisciplineDataTemplateSelector}" />

您正在尝试将 a 分配DataTemplateSelectorDataTemplate属性。

现在,可以有很多方法来实现你想要的。我将创建第三个TemplateSelector,将前两个嵌入为私有属性。

假设你的班级是这样的:

public class MyClass { public bool MyBoolean { get; set; } }

TemplateSelector会是这样的:

public class ThirdSelector : DataTemplateSelector
{
    private DataTemplateSelector _selector1 = new SubdisciplineDataTemplateSelector();
    private DataTemplateSelector _selector2 = new SubdisciplineDataTemplateSelector2();

    public override DataTemplate SelectTemplate(object item, DependencyObject container)
    {
        var obj = item as MyClass;

        if (obj == null)
            return null;

        if (obj.MyBoolean)
            return _selector1.SelectTemplate(item, container);
        else
            return _selector2.SelectTemplate(item, container);
    }
}

这以防您想要/必须保留前两个选择器。如果您可以摆脱它们,请删除它们并将所有逻辑带入新逻辑。

这是一个通用的解决方案,也许如果您共享更多的代码和域对象,可能会有一个更适合您的情况。

于 2017-05-16T14:45:55.743 回答