所以我有一个Master Detail页面。在我的母版页中,我有一个样式,可以设置所有按钮的样式。
母版页
<Style TargetType="Button">
<Setter Property="Background" Value="White" />
<Setter Property="TextBlock.TextAlignment" Value="Center" />
<Setter Property="RenderTransformOrigin" Value="-0.893,-11.7"/>
<Setter Property="VerticalAlignment" Value="Center"/>
</Style>
在我的详细信息页面中,我有一个按钮,我想在其中通过样式添加一些触发器
<Button Content="{Binding DeleteMultipleButton}" Margin="0,0,5,0" CommandParameter="{Binding ElementName=files, Path=SelectedItems}" Command="{Binding DeleteMultipleFiles}">
<Button.Style>
<Style TargetType="{x:Type Button}">
<Setter Property="IsEnabled" Value="True"/>
<Style.Triggers>
<DataTrigger Binding="{Binding Deleting}" Value="True">
<Setter Property="IsEnabled" Value="False"/>
</DataTrigger>
</Style.Triggers>
</Style>
</Button.Style>
</Button>
但这覆盖了继承的样式,我失去了按钮样式。有没有一种方法可以使我的按钮样式基于继承的样式?(我不能通过静态资源和密钥来实现这一点,因为资源在不同的页面中)
您可以使用BasedOn属性:
<Style TargetType="Button" BasedOn="{StaticResource {x:Type Button}}">
保持你的基本按钮风格原样:
<Style TargetType="Button">
<Setter Property="Background" Value="White" />
<Setter Property="TextBlock.TextAlignment" Value="Center" />
<Setter Property="RenderTransformOrigin" Value="-0.893,-11.7"/>
<Setter Property="VerticalAlignment" Value="Center"/>
</Style>
并将BasedOn属性应用于详细信息页面上的按钮:
<Button>
<Button.Style>
<Style TargetType="Button" BasedOn="{StaticResource {x:Type Button}}">
...
</Style>
</Button.Style>
</Button>
因此,因为这两个样式在不同的页面上,所以无法从默认样式继承,所以我所做的是构建一个包含我的样式的App.xaml资源文件,然后在两个页面上添加代码:
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="Resource.xaml" />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
到我的xaml。这意味着我的页面可以通过使用Mike Eason
的代码来覆盖继承的样式:
<Style TargetType="Button" BasedOn="{StaticResource {x:Type Button}}">