如何根据 ViewModel 中的 属性 动态更改 ControlTemplate?

How to dynamically change the ControlTemplate based on a property in a ViewModel?

我想 select 基于 ViewModel 的 属性 动态创建一个 ControlTemplate。如何实现。

我在视图中有 2 个 ControlTemplate,在 ViewModel 中有一个布尔值 属性。基于此 属性,我必须 select 并在视图中显示我的 ControlTempale 之一。

<Window.Resources>
        <ControlTemplate x:Key="simpleErrorTemplate">
            <TextBox Margin="10,10,10,5" TextWrapping="Wrap" VerticalScrollBarVisibility="Auto" Text="T1" />
        </ControlTemplate>
        <ControlTemplate x:Key="detailedErrorTemplate">
            <StackPanel>
                <TextBox Margin="10,10,10,5" TextWrapping="Wrap" VerticalScrollBarVisibility="Auto" Text="T2" />
                <TextBox Margin="10,10,10,5" TextWrapping="Wrap" VerticalScrollBarVisibility="Auto" Text="T3" />
                <TextBox Margin="10,10,10,5" TextWrapping="Wrap" VerticalScrollBarVisibility="Auto" Text="T4" />
            </StackPanel>
        </ControlTemplate>
    </Window.Resources>
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="*" />
            <RowDefinition Height="50" />
        </Grid.RowDefinitions>
        <ContentControl Grid.Row="0" DataContext="{Binding Report}">
            <ContentControl.Style>
                <Style TargetType="ContentControl">
                    <Setter Property="Template" Value="{StaticResource simpleErrorTemplate}"/>
                    <Style.Triggers>
                        <DataTrigger Binding="{Binding IsTyping}" Value="True">
                            <Setter Property="Template" Value="{StaticResource detailedErrorTemplate}"/>
                        </DataTrigger>
                    </Style.Triggers>
                </Style>
            </ContentControl.Style>
        </ContentControl>
        <CheckBox Margin="10,0,0,0" Grid.Row="1" x:Name="ChkShowDetails" IsChecked="{Binding IsTyping, Mode=TwoWay,    UpdateSourceTrigger=PropertyChanged}">Show Details</CheckBox>
    </Grid>

所以根据 IsTyping 的值,我想显示我的 ControlTemplate。 如果我直接将元素绑定到控件模板上,它会起作用,但这不是我的要求。

将数据触发器绑定到正确的 DataContext,即与 CheckBox 绑定到的相同:

<DataTrigger Binding="{Binding DataContext.IsTyping, RelativeSource={RelativeSource AncestorType=ContentControl}}" Value="True">
    <Setter Property="Template" Value="{StaticResource detailedErrorTemplate}"/>
</DataTrigger>

我认为你可以做一些更简单的事情

你需要它来使用ContentControl'sContentTemplateSelector来实现你想要的。

ContentTemplateSelector 是一个自定义 class,它将根据您的数据切换模板。

这会给你一个想法:http://www.wpftutorial.net/datatemplates.html