在样式设置器中添加混合行为
为按钮创建自定义混合行为时,为应用程序中的所有按钮设置它可能具有挑战性。使用内联 XAML,您可以将特定行为与单个对象关联。但是,当通过可应用于多个目标的样式设置行为时,这种方法会遇到限制。
在样式中设置行为的问题
主要问题是行为和触发器与特定对象内在相关。使用内联 XAML 时,XAML 会强制执行这种一对一关系。但是,在样式中定义行为会破坏此原则,因为样式可以在多个目标中重复使用。这会导致基础行为类异常。
此外,与交互相关的“Behaviors”属性的访问权限受到限制,阻止我们通过样式设置值。
解决方案:使用自定义触发器和行为集合
为了应对这些挑战,开发人员设计了一种利用自定义行为和触发器集合类的解决方案。这些类使我们能够在样式中创建和修改行为。
该解决方案背后的关键原则集中在:
示例实现
以下代码示例演示如何实现此解决方案:
<code class="language-xml"><grid> <grid.resources> <triggers x:key="debugTriggers" x:shared="False"> <eventtrigger eventname="MouseLeftButtonDown"> <debugaction message="DataContext: {0}" messageparameter="{Binding}" /> <debugaction message="ElementName: {0}" messageparameter="{Binding Text, ElementName=textBlock2}" /> <debugaction message="Mentor: {0}" messageparameter="{Binding Text, RelativeSource={RelativeSource AncestorType={x:Type FrameworkElement}}}" /> </eventtrigger> </triggers> <Setter Property="local:SupplementaryInteraction.Triggers" Value="{StaticResource debugTriggers}" /> </grid.resources> <stackpanel datacontext="{StaticResource stringResource1}"> <textblock name="textBlock1" style="{StaticResource debugBehavior}" text="textBlock1" /> <textblock name="textBlock2" style="{StaticResource debugBehavior}" text="textBlock2" /> <textblock name="textBlock3" style="{StaticResource debugBehavior}" text="textBlock3" /> </stackpanel> </grid></code>
此示例说明如何在样式中将自定义行为和触发器应用于多个文本块,同时保持正确的 数据绑定和消息生成。
以上是如何使用 XAML 中的样式向多个对象有效添加混合行为?的详细内容。更多信息请关注PHP中文网其他相关文章!