如何处理MVVM(WPF)中的许多复选框?

时间:2017-07-04 08:39:02

标签: c# wpf checkbox mvvm

我有一个扩展程序列表,每个扩展程序都有自己的复选框,用户需要从中选择: enter image description here

最后,我需要选择所有扩展名的List或ObservableCollection。

执行此非MVVM非常简单。我创建了Checked或Unchecked事件,并添加了发件人的内容。

查看:

<CheckBox Checked="ToggleButton_OnChecked" Unchecked="ToggleButton_OnUnchecked">exe</CheckBox>

代码背后:

    private void ToggleButton_OnChecked(object sender, RoutedEventArgs e)
    {
        var ext = ((CheckBox) sender).Content.ToString();
        Model.FirstRun.ExcludeExt.Add(ext);
    }

    private void ToggleButton_OnUnchecked(object sender, RoutedEventArgs e)
    {
        var ext = ((CheckBox)sender).Content.ToString();
        Model.FirstRun.ExcludeExt.Remove(ext);
    }

如果我想做这个MVVM风格,据我所知 - 我必须为每个复选框创建一个属性并将它们绑定到UI。这是很多工作。

有没有更简单的方法?

1 个答案:

答案 0 :(得分:6)

你应该首先考虑一个结构,然后它不是那么多工作而且非常直接使用。

例如:您有扩展组。我会像这样创建一些思考(只是伪代码;例如没有实现INotifyPropertyChanged)。

public class ExtensionGroup
{
    public string Name {get; set;}
    public ObservableCollection<ExtensionInfo> ExtensionInfos {get; set;}
}

public class ExtensionInfo
{
    public string Extension {get; set;}
    public bool IsChecked {get; set;}

    public ExtensionInfo(string extension)
    {
        Extension = extension;
    }
}

在ViewModel中,您可以创建

public ObservableCollection<ExtensionGroup> ExtensionGroups {get; set;}

现在你必须添加像这样的数据

var extensionGroup = new ExtensionGroup{Name = "Executables"};
extensionGroup.ExtensionInfos.Add(new ExtensionInfo("exe");
extensionGroup.ExtensionInfos.Add(new ExtensionInfo("bat");

之后您将拥有一个包含所有组的列表,包括扩展名。

在您查看中,您可以绑定此数据并完成操作。对于视图,您可以将ListView与DataTemplate或其他一些项控件一起使用。

使用更少的代码可以更轻松地查看您的视图,因为您只需要指定一次布局。

/编辑 这是xaml的示例实现。我使用的是ItemsControl而不是ListView

<ItemsControl ItemsSource="{Binding ExtensionGroups}">
    <ItemsControl.ItemTemplate>
        <DataTemplate>
            <StackPanel>
                <Label Content="{Binding Name}"/>
                <ItemsControl ItemsSource="{Binding ExtensionInfos}">
                    <ItemsControl.ItemsPanel>
                        <ItemsPanelTemplate>
                            <WrapPanel />
                        </ItemsPanelTemplate>
                    </ItemsControl.ItemsPanel>
                    <ItemsControl.ItemTemplate>
                        <DataTemplate>
                            <CheckBox IsChecked="{Binding IsChecked}"
                                      Content="{Binding Extension}"/>
                        </DataTemplate>
                    </ItemsControl.ItemTemplate>
                </ItemsControl>
            </StackPanel>
        </DataTemplate>
    </ItemsControl.ItemTemplate>
</ItemsControl>

看起来像这样(只添加了两个包含两个扩展名的组)。 Example