2008-12-07 89 views
2

我是新来WPF和数据绑定,所以希望我可以解释我有足够的细节得到一些帮助的问题。数据绑定到数据绑定对象内的列表

我有一个数据绑定到窗口的对象列表。假设它是一份食谱列表。我设法让应用程序在列表框中显示每个配方的一些细节,以及在各种文本框中选择的配方的更多细节。我的问题是,我在每个配方中都有一个配料列表,当我选择配方时,我想在另一个列表框中显示配料列表,但我无法弄清楚如何让数据绑定工作。

我的数据类看起来像:

public class Recipes : ObservableCollection<RecipeDetails> 
{ 
} 

public class RecipeDetails 
{ 
    public string Name { get; set; } 
    public string Description { get; set; } 
    public List<RecipeIngredient> Ingredients; 
} 

public class RecipeIngredient 
{ 
    public string IngredientName { get; set; } 
} 


public partial class MainWindow : Window 
{ 
    public MainWindow() 
    { 
     InitializeComponent(); 
     m_recipes = new Recipes(); 
     // m_recipes initialisation 
    } 

    private void Window_Loaded(object sender, RoutedEventArgs e) 
    { 
     DataContext = m_recipes; 
    } 

    private Recipes m_recipes; 
} 

我的数据绑定尝试(在XAML)看起来像:

<Window x:Class="RecipeWindow.MainWindow" 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    Title="Recipe Window" Height="402.687" Width="532.674" Loaded="Window_Loaded"> 
    <Grid> 
     <ListBox Margin="12,58.176,0,16.362" Name="recipeListBox" Width="209.07" IsSynchronizedWithCurrentItem="True" ItemsSource="{Binding}"> 
      <ListBox.ItemTemplate> 
       <DataTemplate> 
        <TextBlock Text="{Binding Name}" FontSize="14" Padding="5" /> 
       </DataTemplate> 
      </ListBox.ItemTemplate> 
     </ListBox> 
     <StackPanel Margin="245.43,58.176,12,47.268" Name="detailsPanel"> 
      <TextBox Text="{Binding Name,UpdateSourceTrigger=PropertyChanged}" Width="140" /> 
      <TextBox Text="{Binding Description,UpdateSourceTrigger=PropertyChanged}" Width="140" /> 
      <ListBox Name="ingredientListBox" Width="209.07" ItemsSource="{Binding Ingredients}" Height="118.17"> 
       <ListBox.ItemTemplate> 
        <DataTemplate> 
         <TextBlock Text="{Binding IngredientName}" Padding="5" /> 
        </DataTemplate> 
       </ListBox.ItemTemplate> 
      </ListBox> 
     </StackPanel> 
    </Grid> 
</Window> 

但是当我尝试运行这段代码,成分表盒子总是空的。谁能告诉我我做错了什么?

回答

5

的问题是因为你的方式声明和初始化配料清单,让它作为的ObservableCollection和如下

public class RecipeDetails 
{ 
    public RecipeDetails() 
    { 
     _ingredients = new ObservableCollection<RecipeIngredient>(); 
    } 

    public string Name { get; set; } 
    public string Description { get; set; } 

    private ObservableCollection<RecipeIngredient> _ingredients; 

    private ObservableCollection<RecipeIngredient> Ingredients 
    { 
     get { return _ingredients; } 
    } 
} 

还有一点要添加到您的方法只在构造函数初始化成分集合,它是建议在该类上使用INotifyPropertyChanged,以便在TextBox中键入某些内容时可以轻松实现双向绑定。

+0

工作就像一个魅力,除非我不需要在构造函数中初始化它。使其成为一个公共财产,如: public ObservableCollection 成分 {get;组; } 似乎工作正常。 – Bonnici 2008-12-07 08:49:45