我有一个DataGrid
,遵循 XAML:
<DataGrid ItemsSource="{Binding Path=propCollection}"
SelectedItem="{Binding Path=SelectProp, Mode=TwoWay}"
Margin="-1,159,0,0"
RowDetailsVisibilityMode="Visible"
AreRowDetailsFrozen="False"
CanUserReorderColumns="False"
CanUserSortColumns="True"
CanUserResizeRows="False"
SelectionUnit="FullRow"
AlternatingRowBackground="{x:Null}"
SelectionChanged="dgProprietarios_SelectionChanged"
AlternationCount="0"
Height="200"
HorizontalAlignment="Left"
Name="dgProprietarios"
VerticalAlignment="Top"
Width="645"
AutoGenerateColumns="False">
<...Columns...>
</DataGrid>
在我的Window_Loaded 上,我执行以下操作:
dgProprietarios.DataContext = new ProprietariosViewModel(new Dictionary<string, string>());
我的ProprietariosViewModel如下:
public CollectionProprietarios propCollection { get; set; }
public ProprietariosViewModel(Dictionary<string, string> Where)
{
propCollection = new CollectionProprietarios(Where);
}
CollectionProprietarios类继承ObservableCollection并具有以下代码:
public CollectionProprietarios(Dictionary<string, string> Where)
{
Add(new Dados(Where));
}
public new void Add(Dados dados)
{
base.Add(dados);
}
类Dados具有以下代码:
public DataTable ProprietariosRetorno { get; private set; }
public Dados(Dictionary<string, string> Where)
{
var ado = new ADO();
ProprietariosRetorno = ado.RetornaSelect(MontaQuery(Where));
}
函数MontaQuery只是创建一个包含 SELECT 子句的字符串,而RetornaSelect执行此查询。
ADO类在实例化时只创建数据库和表(如果它不存在)。
问题是,所有这些都在起作用。在调试时,我可以检索 DataContext 中的值,它包含带有值的 DataTable。但是由于某种原因,程序运行时它没有出现在 DataGrid 上。
所以问题是,我做错了什么?