1

我有一个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 上。

所以问题是,我做错了什么?

4

1 回答 1

1

尝试使用

dgProprietarios.DataContext = new ProprietariosViewModel(new Dictionary<string, string>());
dgProprietarios.Items.Refresh();
于 2012-12-04T12:58:46.817 回答