数据绑定到列表框项模板不起作用

时间:2013-03-07 19:08:44

标签: c# wpf templates data-binding listbox

我有以下代码。它构建并运行但不填充列表框。有人能发现错误吗?

 <Grid>
        <ListBox ItemsSource="{Binding Path=questions}" Height="401" HorizontalAlignment="Left" Name="results" VerticalAlignment="Top" Width="260" Margin="0,20,0,0">
                <ListBox.ItemTemplate>
                    <DataTemplate>
                        <StackPanel Orientation="Vertical">
                            <StackPanel Orientation="Horizontal">
                                <StackPanel Orientation="Vertical">
                                    <TextBlock Text="{Binding Path=question.votes}" FontSize="15" Padding="5" Background="White" Foreground="Black"/>
                                <TextBlock Text="{Binding Path=question.answers}" FontSize="15" Padding="5" Background="White" Foreground="Black"/>
                                </StackPanel>
                                <StackPanel Orientation="Vertical" Height="Auto" Width="249">
                                <TextBlock Text="{Binding Path=question.title}" FontWeight="Bold" Background="#FF92F2CD" Height="22" Width="229" Foreground="Black"/>
                                <TextBlock Text="{Binding Path=question.body}" TextWrapping="Wrap" Height="43" Width="231" Background="#FFEFEFEF" Foreground="Black"/>
                                </StackPanel>
                            </StackPanel>
                            <StackPanel>
                            <TextBlock Text="{Binding Path=question.tags}" Foreground="#FFFF9C00" Background="#FF4E3D3D" FontWeight="Bold" TextAlignment="Center"/>
                            </StackPanel>
                        </StackPanel>
                    </DataTemplate>
                </ListBox.ItemTemplate>       
        </ListBox>
        <Button Content="Refresh" Height="22" HorizontalAlignment="Left" Name="button1" VerticalAlignment="Top" Width="54" />
    </Grid>




public class question 
{
    public string votes     { get; set; }
    public string answers   { get; set; }
    public string title     { get; set; }
    public string body      { get; set; }
    public string tags      { get; set; }

}

public partial class MainWindow : Window
{

    ObservableCollection<question> questions = new ObservableCollection<question>();

    public MainWindow() 
    {
        questions.Add(new question
        {
            votes = "2",
            answers = "3",
        title = "This is a sample title",
        body = "This is a sample body text. It should wrap and not look like shit when presented.",
        tags = "C#,WPF,XML,JediStyle"

    });
    this.DataContext = this;

    InitializeComponent();

    }
}

3 个答案:

答案 0 :(得分:2)

绑定不适用于字段,但适用于属性。

ObservableCollection<question> questions = new ObservableCollection<question>();

ObservableCollection<question> MyQuestions
{
    get { return questions; }
}

在XAML中

ItemsSource="{Binding Path=MyQuestions}"

您也不必将question指定为特定列表项中每个绑定的路径的一部分:

Text="{Binding Path=question.tags}"应为Text="{Binding Path=tags}"或更简单:Text="{Binding tags}"

答案 1 :(得分:0)

        <ListBox ItemsSource="{Binding Path=questions}" Height="401" HorizontalAlignment="Left" Name="results" VerticalAlignment="Top" Width="260" Margin="0,20,0,0">
            <ListBox.ItemTemplate>
                <DataTemplate>
                    <StackPanel Orientation="Vertical">
                        <StackPanel Orientation="Horizontal">
                            <StackPanel Orientation="Vertical">
                                <TextBlock Text="{Binding Path=votes}" FontSize="15" Padding="5" Background="White" Foreground="Black"/>
                            <TextBlock Text="{Binding Path=answers}" FontSize="15" Padding="5" Background="White" Foreground="Black"/>
                            </StackPanel>
                            <StackPanel Orientation="Vertical" Height="Auto" Width="249">
                            <TextBlock Text="{Binding Path=title}" FontWeight="Bold" Background="#FF92F2CD" Height="22" Width="229" Foreground="Black"/>
                            <TextBlock Text="{Binding Path=body}" TextWrapping="Wrap" Height="43" Width="231" Background="#FFEFEFEF" Foreground="Black"/>
                            </StackPanel>
                        </StackPanel>
                        <StackPanel>
                        <TextBlock Text="{Binding Path=tags}" //am not sure from where this tags coming
Foreground="#FFFF9C00" Background="#FF4E3D3D" FontWeight="Bold" TextAlignment="Center"/>
                        </StackPanel>
                    </StackPanel>
                </DataTemplate>
            </ListBox.ItemTemplate>       
    </ListBox>

答案 2 :(得分:0)

我会尝试使用ViewModel ...

Good Article

Another Good Article

这两篇文章强调了完全绑定的好处,并进入NotifyPropertyChanged和命令。值得一读。