DataGridView привязан к DataTable без отображения строк - PullRequest
1 голос
/ 31 марта 2012

У меня есть DataTable, который я заполняю вручную для привязки к DataGridView. Когда я вручную добавляю строку в DataTable, она не отображается в DataGridView. Столбцы есть, но теперь строки.

Есть идеи?

((DataTable)((BindingSource)_dgv.DataSource)).Rows.Count // 2
_dgv.Rows.Count // 0
_dgv.Columns[0].IsDataBound // true, for all columns

//code that adds rows
DataRow productRow = dataTable.NewRow();
SetRowValues(productRow);
dataTable.Rows.Add(productRow);

//code to bind DataTable to DGV
BindingSource bindingSrc = new BindingSource();
bindingSrc.DataSource = dataTable;
DataGridView dgv = CreateDataGridView();
dgv.DataSource = bindingSrc;

private DataGridView CreateDataGridView()
{
    DataGridView dgv = new DataGridView();
    dgv.Anchor = (AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right | AnchorStyles.Top);
    dgv.ShowEditingIcon = false;
    dgv.RowHeadersVisible = false;
    dgv.ReadOnly = true;
    dgv.AllowUserToAddRows = false;
    dgv.ColumnHeadersVisible = true;
    dgv.CellDoubleClick += new DataGridViewCellEventHandler(OnDGVCellDoubleClick);
    dgv.SelectionChanged += new EventHandler(OnDGVSelectionChanged);
    dgv.AutoGenerateColumns = false;
    List<OpportunityProductField> configFields = GetConfigFields();
    List<DataGridViewColumn> columns = CreateDGVColumns(configFields);
    columns.Sort(delegate(DataGridViewColumn c1, DataGridViewColumn c2) { return c1.DisplayIndex.CompareTo(c2.DisplayIndex); });
    columns.ForEach(delegate(DataGridViewColumn c) { dgv.Columns.Add(c); });
    return dgv;
}

1 Ответ

0 голосов
/ 31 марта 2012

Разве ваш код для привязки не должен выглядеть так?

BindingSource bindingSrc = new BindingSource();
bindingSrc.DataSource = dataTable
DataGridView dgv = CreateDataGridView();
dgv.DataSource = bindingSrc;
...