首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C# -具有动态数量的可绑定属性的类

C# -具有动态数量的可绑定属性的类
EN

Stack Overflow用户
提问于 2011-05-20 03:38:26
回答 2查看 819关注 0票数 2

我有X个RadioButtons (Silverlight)。正常情况下,此值在2-5之间。叫它“开关”吧。每个单选按钮都绑定到该类的一个属性。

示例属性如下所示

代码语言:javascript
复制
private bool _radio1;
public bool Radio1{
 set{
  _radio1 = value;
  _radioX = !value; // make all others false
 }
 get{ return _radio1 }
}

基本思想是,如果选择了一个无线电,则所有其他无线电都会被关闭。

我尝试过使用其他方法,与使用模板创建列表相比,这种方法似乎是最简单的(特别是在某些情况下,我通过单选按钮使用其他按钮时)

目前我有两个要求,我需要一个具有2个属性的类(例如,男性/女性)复选框和3个属性。

未来可能会有更多,因此我认为为X数量的单选按钮编写一个新类是愚蠢的。

有没有办法让一些属性以某种方式动态化?我看到了一些字典方法。

我在How do I create dynamic properties in C#?上看到了这种方法

不过,我不确定如何绑定它。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-05-20 04:05:13

尽管使用C#的动态特性很有趣,但在这种情况下并不需要。好的老式数据绑定足够强大,可以做我们想做的事情。例如。下面是一些使用RadioButton模板将ItemsControl绑定到集合的XAML:

代码语言:javascript
复制
<Grid>
    <StackPanel>
        <ItemsControl ItemsSource="{Binding}">
            <ItemsControl.ItemTemplate>
                <DataTemplate>
                    <RadioButton
                        GroupName="Value"
                        Content="{Binding Description}"
                        IsChecked="{Binding IsChecked, Mode=TwoWay}"/>
                </DataTemplate>
            </ItemsControl.ItemTemplate>
        </ItemsControl>
        <TextBlock Text="{Binding SelectedItem}"/>
    </StackPanel>
</Grid>

下面是如何在代码隐藏或视图模型中使用它:

代码语言:javascript
复制
DataContext = new CheckBoxValueCollection(new[] { "Foo", "Bar", "Baz" });

现在,您所需要的就是让它工作的集合。下面是复选框值的集合:

代码语言:javascript
复制
public class CheckBoxValueCollection : ObservableCollection<CheckBoxValue>
{
    public CheckBoxValueCollection(IEnumerable<string> values)
    {
        foreach (var value in values)
        {
            var checkBoxValue = new CheckBoxValue { Description = value };
            checkBoxValue.PropertyChanged += (s, e) => OnPropertyChanged(new PropertyChangedEventArgs("SelectedItem"));
            this.Add(checkBoxValue);
        }
        this[0].IsChecked = true;
    }

    public string SelectedItem
    {
        get { return this.First(item => item.IsChecked).Description; }
    }
}

下面是复选框值本身:

代码语言:javascript
复制
public class CheckBoxValue : INotifyPropertyChanged
{
    private string description;
    private bool isChecked;

    public string Description
    {
        get { return description; }
        set { description = value; OnPropertyChanged("Description"); }
    }
    public bool IsChecked
    {
        get { return isChecked; }
        set { isChecked = value; OnPropertyChanged("IsChecked"); }
    }

    public event PropertyChangedEventHandler PropertyChanged;

    protected void OnPropertyChanged(string propertyName)
    {
        if (PropertyChanged != null) PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
    }
}

现在,您有了一个完全动态的数据驱动和数据绑定友好的单选按钮设计。

示例程序如下所示:

单选按钮下方的文本显示当前选定的项目。尽管在本例中我使用了字符串,但是您可以很容易地更改设计,以使用enum值或其他来源来描述单选按钮。

票数 5
EN

Stack Overflow用户

发布于 2011-05-20 03:59:59

也许你应该尝试使用绑定到字典?(或者指向带有thisstring x索引器的对象?)

如下所示:

代码语言:javascript
复制
public class AnyGroup : INotifyPropertyChanged
{
    public event PropertyChangedEventHandler PropertyChanged;

    IDictionary<string, bool> _options;
    public AnyGroup(IDictionary<string, bool> options)
    {
        this._options = options;
    }

    public bool this[string a]
    {
        get
        {
            return _options[a];
        }
        set
        {
            if (value)
            {
                var other = _options.Where(p => p.Key != a).Select(p => p.Key).ToArray();
                foreach (string key in other)
                    _options[key] = false;
                _options[a] = true;

                if (PropertyChanged != null) PropertyChanged(this, new PropertyChangedEventArgs("Item[]"));
            }
            else
                _options[a] = false;                
        }
    }        
}

数据绑定将如下所示:

代码语言:javascript
复制
cbGroup.DataContext = new AnyGroup(new Dictionary<string, bool>() { {"male", true}, {"female", false} } );

..。

代码语言:javascript
复制
<StackPanel Name="cbGroup">
    <CheckBox IsChecked="{Binding [male], Mode=TwoWay}" />
    <CheckBox IsChecked="{Binding [female], Mode=TwoWay}" />
</StackPanel>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6063974

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档