繁体   English   中英

WPF MVVM:将命令绑定到事件

[英]WPF MVVM: binding command to event

我有我的视图和viewmodel文件。 在我的视图模型中,我有以下简单代码:

private void Filter(string keyword)
{
    Debug.Print("******START********");
    string stringToSearch = keyword.ToLower();
    ObservableCollection<TabImpianti> listBoxSource = new ObservableCollection<TabImpianti>();
    foreach (TabImpianti ti in p_ListaImpianti)
    {
        if (ti.NOME.ToString().ToLower().Contains(stringToSearch))
            listBoxSource.Add(ti);
    }
    p_ListaImpianti = listBoxSource;
    Debug.Print("******END********");
}

在我的xaml中,我有:

<dxe:TextEdit  ValidateOnTextInput="True" Margin="105,10,797,631" />

哑巴问题:如何将我的函数绑定到事件EditValueChanged,还像参数一样传递文本框的内容? 简单的目标是:当用户在文本框中写一些内容时,过滤绑定到视图模型的集合。

在网上,我发现了很多教程,代码段等,但是其中任何一个都可以帮助我理解。

可以用类似的方法完成。

例如:-

<TextBox Margin="89,116,69,123" x:Name="txtFilter" Background="AliceBlue" >
        <i:Interaction.Triggers>
            <i:EventTrigger EventName="TextChanged">
                <cmd:EventToCommand Command="{Binding SearchedTextChanged}" CommandParameter="{Binding Text, ElementName=txtFilter}"/>
            </i:EventTrigger>
        </i:Interaction.Triggers>
    </TextBox>

调查

http://www.c-sharpcorner.com/Blogs/11789/example-of-eventtrigger-in-mvvm-application.aspx http://social.msdn.microsoft.com/Forums/vstudio/en-US/fd819518 -605a-46ae-a9e4-26556d0f3e15 / wpf-textbox-trigger?forum = wpf

再举一个例子。

请看以下出色的文章,其中清楚地描述了与EventToCommand行为的DevExpress实现有关的所有方面: DevExpress MVVM Framework。 EventToCommand。 使用这种方法,您可以按以下步骤执行任务:

<dxe:TextEdit Margin="89,116,69,123" x:Name="txtFilter" Background="AliceBlue" >
    <dxmvvm:Interaction.Behaviors> 
        <dxmvvm:EventToCommand EventName="EditValueChanged" Command="{Binding FilterCommand}"
            CommandParameter="{Binding ElementName=txtFilter, Path=Text}"/> 
    </dxmvvm:Interaction.Behaviors> 
...
[POCOViewModel]
public class CoolectionViewModel {
    [Command]
    public void Filter(string searchText) {
        ...
    }
}

PS使用DevExpress控件,您可以通过搜索框完成对列表框控件项的过滤,而无需进行任何编码。 只需将ListBoxEdit.FilterCriteria属性绑定到SearchControl.FilterCriteria属性即可:

<Grid>
    <Grid.RowDefinitions>
        <RowDefinition/>
        <RowDefinition/>
    </Grid.RowDefinitions>
    <dxe:SearchControl x:Name="searchControl" Grid.Row="0" Margin="10"
                     HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
    <dxe:ListBoxEdit Name="listBox" Grid.Row="1"  Margin="10"
                     HorizontalAlignment="Stretch" VerticalAlignment="Stretch"
                     DisplayMember="Name" ValueMember="ID"
                     FilterCriteria="{Binding FilterCriteria, ElementName=searchControl}"/>
</Grid>

您可以使用下面的演示来使用这种方法(链接指向Silverlight版本,但WPF版本的行为完全相同)。 您可以对DX中的任何列表控件(ListBoxEdit,ComboBoxEdit,DXGrid等)使用相同的方法。

可以将TextEdit的text属性绑定到ViewModel的属性,并监视ViewModel的该属性(PropertyChanged ?!),而不是将ViewModel函数绑定到View事件。

该属性更改后,您就可以执行该功能。

这样,您仍然可以通过依赖于引发事件来测试ViewModel,而无需将其绑定到View。

您的TextEdit控件应绑定到ViewModel中的属性。 在该属性的设置器中,您将调用Filter方法。

本示例假定您的TextEdit控件具有Text属性。 如果不是,请更改为绑定到任何属性名称。

<dxe:TextEdit Text="{Binding MyTextValue}"  ValidateOnTextInput="True" Margin="105,10,797,631" />

然后在ViewModel类中:

private string _myTextValue;
public string MyTextValue {
    get {
        return _myTextValue;
    }
    set {
        if (value != _myTextValue) {
            _myTextValue = value;
            Filter(_myTextValue);
        }
    }
 }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM