问题:DataGridComboBox上的大多数代码示例似乎都使用静态资源作为ItemsSource。在我的用例中,我想为每个绑定对象提供不同的ItemsSources。 可以这样做吗?
背景:我正在尝试使用DataGridComboBoxColumn控件将一组Question类对象绑定到WPF DataGrid。 Answer字符串提供SelectedValue。我希望AnswerDomain列表为每个ComboBox提供ItemsSource。 AnswerDomain与问题不同。
类
public class Question
{
string Answer {get; set;}
List<string> AnswerDomain {get; set;}
//...other stuff
}
XAML
<DataGrid ItemsSource="{Binding Path=InspectionItems}" AutoGenerateColumns="False" Name="dataGrid1" >
<DataGrid.Columns>
<DataGridComboBoxColumn Header="Answer Domain"
DisplayMemberPath="Answer"
SelectedValuePath="Answer"
ItemsSource="{Binding Path=AnswerDomain}"
>
</DataGridComboBoxColumn>
</DataGrid.Columns>
</DataGrid>
问题:有几个问题。现在的关键问题是每个DataGrid Row中的ComboBox都没有显示AnswerDomain字符串。我尝试过一系列XAML组合但没有成功。帮我Stack Overflow。
更新:以下所选解决方案有效。在进一步摸索并将UpdateSourceTrigger=PropertyChanged
添加到SelectedItem之后,组合框中的用户更改会反映在底层自定义对象中。
<DataGridTemplateColumn Header="Answer">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<ComboBox
ItemsSource="{Binding AnswerDomain}"
SelectedItem="{Binding Answer, UpdateSourceTrigger=PropertyChanged}" />
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
答案 0 :(得分:10)
您的问题是显示成员路径不是Answer,因为字符串没有“Answer”属性。我从不使用DataGridComboBoxColumn,它对我来说似乎不太自然,太像旧的win形式方式。请尝试以下方法。但请确保您在问题类上执行INotifyPropertyChanged,并触发相应的事件。
<DataGridTemplateColumn>
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<ComboBox ItemsSource="{Binding AnswerDomain}" SelectedItem="{Binding Answer}" />
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
以下是您的问题类的外观:
public class Question : INotifyPropertyChanged
{
private string m_Answer;
public string Answer
{
get { return m_Answer; }
set
{
if (m_Answer != value)
{
m_Answer = value;
FirePropertyChanged("Answer");
}
}
}
private List<string> m_AnswerDomain;
public List<string> AnswerDomain
{
get { return m_AnswerDomain; }
set
{
if (m_AnswerDomain != value)
{
m_AnswerDomain = value;
FirePropertyChanged("AnswerDomain");
}
}
}
[field: NonSerialized]
public event PropertyChangedEventHandler PropertyChanged;
private void FirePropertyChanged(string propertyName)
{
if (this.PropertyChanged != null)
this.PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
}
}