这甚至可能吗?我有两个ObservableCollections。我想用其中一个绑定和填充列表框。例如,假设我们有2个按钮 - 一个用于Twitter,一个用于Facebook。单击Facebook按钮,它将使用来自facebook observable collection的朋友名称填充列表框,它将绑定它。点击Twitter,它将使用Twitter粉丝填充列表框并填充列表框并绑定它。
如何选择将在列表框中填充哪个集合?
答案 0 :(得分:2)
我会根据用户的选择使用一个可观察的集合和填充。你也可以用两个来源的名字填充它,并有一个过滤器来过滤掉一个或另一个(显然你需要一个包装器对象,你可以指出该名称是Facebook的朋友或Twitter粉丝)。
修改:以下是一些快速代码示例,说明如何执行此操作:
public interface ISocialContact
{
string Name { get; }
}
public class FacebookContact : ISocialContact
{
public string Name { get; set; }
public string FacebookPage { get; set; }
}
public class TwitterContact : ISocialContact
{
public string Name { get; set; }
public string TwitterAccount { get; set; }
}
然后在您的数据环境中:
public ObservableCollection<ISocialContact> Contacts { get; set; }
...
Contacts = new ObservableCollection<ISocialContact> {
new FacebookContact { Name = "Face", FacebookPage = "book" },
new TwitterContact { Name = "Twit", TwitterAccount = "ter" }
};
在你的xaml中:
<Grid>
<Grid.Resources>
<DataTemplate DataType="{x:Type local:FacebookContact}">
<TextBlock Text="{Binding FacebookPage}"/>
</DataTemplate>
<DataTemplate DataType="{x:Type local:TwitterContact}">
<TextBlock Text="{Binding TwitterAccount}"/>
</DataTemplate>
</Grid.Resources>
<ListBox ItemsSource="{Binding Contacts}" Width="100" Height="100"/>
</Grid>
这会将适当的模板应用于集合中的每个对象。所以你可以只收集facebook联系人或只是推特联系人或混合收集。
另请注意:您不需要通用界面。如果您只使ObservableCollection
类型为object
,它也会有用。但是,假设它们在同一个列表框中由同一个应用程序显示,则表示您可以找到某种公共基础,并且可以创建一个comon接口或基类。
答案 1 :(得分:0)
在ViewModel中,创建一个公开一个或另一个ObservableCollection的属性,并在单击该按钮时将其交换出来:
private ObservableCollection<string> _twitterFriendList;
private ObservableCollection<string> _facebookFriendList;
private ObservableCollection<string> _selectedFriendList;
public ObservableCollection<string> SelectedFriendList
{
get { return _selectedFriendList; }
set
{
if (value != _selectedFriendList)
{
_selectedFriendList = value;
RaisePropertyChanged("SelectedFriendList");
}
}
}
void TwitterButton_Click(object sender, RoutedEventArgs e)
{
SelectedFriendList = _twitterFriendList;
}
void FacebookButton_Click(object sender, RoutedEventArgs e)
{
SelectedFriendList = _facebookFriendList;
}
然后在你的XAML中你可以绑定到属性:
<ListBox ItemsSource="{Binding SelectedFriendList}"/>
答案 2 :(得分:0)
实现此目的的一种非优雅方式是将2个列表框放在同一位置,并将1绑定到twitter集合,将另一个绑定到facebook集合。将其可见性绑定到基于按钮单击更改的属性。就个人而言,我有2个单选按钮,并根据选择的列表框显示列表框。
<ListBox Grid.Row="0" Grid.Column="0" ItemsSource="{Binding Path=TwitterCollection}" SelectedItem="{Binding Path=SelectedTwitterItem}" Visibility="{Binding Path=IsTwitterSelected, Converter={StaticResource visibilityConverter}}" />
<ListBox Grid.Row="0" Grid.Column="0" ItemsSource="{Binding Path=FacebookCollection}" SelectedItem="{Binding Path=SelectedFacebookItem}" Visibility="{Binding Path=IsFacebookSelected, Converter={StaticResource visibilityConverter}}" />
<RadioButton Grid.Row="1" Grid.Column="0" GroupName="rdoOptions" Content="{Binding Path=TwitterLabel}" IsChecked="{Binding Path=IsTwitterSelected}" />
<RadioButton Grid.Row="1" Grid.Column="1" GroupName="rdoOptions" Content="{Binding Path=FacebookLabel}" IsChecked="{Binding Path=IsFacebookSelected}" />