Bxf and CSLA .NET both include a TriggerAction control. This control helps support the MVVM design pattern in WPF, Silverlight, and WP7 applications.
(Bxf is completely independent from CSLA – I donated TriggerAction from CSLA to the Bxf project a while back though, so this type is available from either framework)
The specific problem addressed by TriggerAction is the need to invoke a verb (method/command) on your viewmodel object in response to any arbitrary UI event. One common UI event is something like a button click event, though you can often use commanding in that case. But there are numerous other UI events from many controls other than buttons, and you might want to have one of those UI events cause the viewmodel to perform an action.
TriggerAction basically wires arbitrary UI events to methods on the current DataContext (usually the viewmodel object).
<bxf:TriggerAction TargetControl="{Binding ElementName=MyControl}"
TriggerEvent="MouseOver"
DataContext="{Binding Source={StaticResource vm}}"
MethodName="MyAction" />
TriggerAction listens for the trigger event from the TargetControl. When it handles that event, it invokes the specified method (MethodName) on its current DataContext object. There’s nothing more to it.
To get TriggerAction working you need two things: source and target.
Source:
MethodParameter may be set (to a value or binding expression)
RebindParameterDynamically may be set to true (to force rebinding of MethodParameter to work around issues with certain control properties such as ListBox.SelectedItems)
The most common causes of failure when using TriggerAction are that the TargetControl isn’t set right, or the DataContext isn’t set right, and of those two the most common is that the DataContext isn’t what you think it is (that happens to me all the time).
Read more: ROCKFORD LHOTKA
(Bxf is completely independent from CSLA – I donated TriggerAction from CSLA to the Bxf project a while back though, so this type is available from either framework)
The specific problem addressed by TriggerAction is the need to invoke a verb (method/command) on your viewmodel object in response to any arbitrary UI event. One common UI event is something like a button click event, though you can often use commanding in that case. But there are numerous other UI events from many controls other than buttons, and you might want to have one of those UI events cause the viewmodel to perform an action.
TriggerAction basically wires arbitrary UI events to methods on the current DataContext (usually the viewmodel object).
<bxf:TriggerAction TargetControl="{Binding ElementName=MyControl}"
TriggerEvent="MouseOver"
DataContext="{Binding Source={StaticResource vm}}"
MethodName="MyAction" />
TriggerAction listens for the trigger event from the TargetControl. When it handles that event, it invokes the specified method (MethodName) on its current DataContext object. There’s nothing more to it.
To get TriggerAction working you need two things: source and target.
Source:
- TargetControl must be set
- TriggerEvent may be set (default is “Click”)
- DataContext must be set (or inherited from the container)
- MethodName must be set
MethodParameter may be set (to a value or binding expression)
RebindParameterDynamically may be set to true (to force rebinding of MethodParameter to work around issues with certain control properties such as ListBox.SelectedItems)
The most common causes of failure when using TriggerAction are that the TargetControl isn’t set right, or the DataContext isn’t set right, and of those two the most common is that the DataContext isn’t what you think it is (that happens to me all the time).
Read more: ROCKFORD LHOTKA