【问题标题】:DataBinding To Two Sources数据绑定到两个源
【发布时间】:2011-09-27 22:39:44
【问题描述】:

我需要使用两个列表框,每个都绑定到不同的集合。

在需要绑定两个之前,我最初使用一个列表框和绑定。 以下是我的做法。

 <Window x:Class="TeamManager.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:loc ="clr-namespace:TeamManager"
    Title="Game Manager" Height="800" Width="800">

<Window.Resources>
    <DataTemplate DataType="{x:Type loc:Game}">
        <Grid>
            <Grid.RowDefinitions>
                <RowDefinition Height="auto"></RowDefinition>
            </Grid.RowDefinitions>
            <Grid.ColumnDefinitions>

                <ColumnDefinition Width="100"></ColumnDefinition>
                <ColumnDefinition Width="100"></ColumnDefinition>
                <ColumnDefinition Width="100"></ColumnDefinition>
                <ColumnDefinition Width="100"></ColumnDefinition>
            </Grid.ColumnDefinitions>
            <TextBlock Name="dateBlock" Grid.Column="0" Grid.Row="1" Text="{Binding Date,  StringFormat=d}"></TextBlock>
            <TextBlock Name="TimeBlock" Grid.Column="1" Grid.Row="1" Text="{Binding Time}"></TextBlock>
            <Button Grid.Row="1" Grid.Column="2" CommandParameter="{Binding Id}" Click="Manage_Click" >Manage</Button>
            <Button Grid.Row="1" Grid.Column="3" CommandParameter="{Binding Id}" Click="Delete_Click" Height="16" Width="16">
                <Image Source="/Images/DeleteRed.png"></Image>

            </Button>
        </Grid>
    </DataTemplate>
</Window.Resources>
<StackPanel>

    <StackPanel Orientation="Horizontal" HorizontalAlignment="Left">

        <StackPanel>
            <TextBlock>Upcomming Games</TextBlock>
            <ListBox ItemsSource="{Binding}" Name="GameList"></ListBox>
        </StackPanel>
        <StackPanel Orientation="Vertical" HorizontalAlignment="Left">
            <Button Height="30" Width="100" Margin="10,10,10,10" Click="AddGame_Click">Add New Game</Button>
        </StackPanel>
    </StackPanel>
</StackPanel>

而我的代码只是将窗口的 DataContext 设置为 ObservableCollection

由于需要使用两个集合,我创建了一个这样的包装类

    public class AppModel
{


    public ObservableCollection<Game> gameCollection { get; set; }
    public ObservableCollection<Player> playerCollection { get; set; }

}

我的 CS 现在正在将 DataContext 设置为 AppModel 的对象

    GameDBEntities _entity = new GameDBEntities();
    AppModel _model;
    public MainWindow()
    {
          InitializeComponent();

          DataContext = model;
    }


    AppModel model
    {
        get
        {
            if (_model == null)
            {
                _model = new AppModel();
            }
            if (_model.gameCollection == null)
            {
                _model.gameCollection = new ObservableCollection<Game>(_entity.Games);
            }
            if (_model.playerCollection == null)
            {
                _model.playerCollection = new ObservableCollection<Player>(_entity.Players);
            }
            return _model;
        }
        set { }

    }

在我的 Xaml 中,如何将现有 listBox 的数据上下文设置为绑定到 AppModel 中的游戏集合? 一旦我开始工作,我将自己处理第二个列表框。 谢谢!

【问题讨论】:

    标签: c# wpf xaml data-binding


    【解决方案1】:

    您需要将Path 添加到BindingDatacContext 将是模型,路径应指向任一集合:

    <ListBox ItemsSource="{Binding gameCollection}" ...
    

    【讨论】:

      【解决方案2】:

      将绑定更改为&lt;ListBox ItemsSource="{Binding Path=gameCollection}" Name="GameList"&gt;&lt;/ListBox&gt; 会解决您的问题吗?

      根据您的问题,您说您曾经将 DataContext 设置为 gameCollection,但现在您已将其更改为使用 AppModel,您还需要根据需要更改绑定。

      这将从本质上改变绑定,从只是绑定到 gameCollection,它现在将被设置为使用 AppData.gameCollection。

      【讨论】:

        猜你喜欢
        • 2013-10-21
        • 1970-01-01
        • 2019-02-05
        • 1970-01-01
        • 2010-09-20
        • 1970-01-01
        • 2019-01-29
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多