Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Разработка Windows Forms > Обновление записей dataGridView


Автор: coddy 8.4.2010, 09:19
Добрый день!
имеется dataGridView. Свойство DataSource которогу установленно на объект report.Table (тип - EntitySet<Table>).

Создаю новый объект Table и добавляю его в коллекцию.
Код

var tbl = new Table {Good_id = SelectedGood.Id, Price = Convert.ToDecimal(SelectedGood.Default_price)};
report.Table.Add(tbl); 

Изменений в dataGridView при этом не происходит - новая строка не добавляется :(

Пытался обновить биндинг:
Код

dgvTable.DataSource = null;
dgvTable.DataSource = report.Table;
dgvTable.Refresh();

Безуспешно.

Как заставить грид автоматически добавлять новые строки, при добавлении объектов в коллекцию?

Автор: jonie 8.4.2010, 09:59
унаследуйте report.Table дополнительно от INotifyCollectionChanged, реализуйте его и сделайте в методе Add вызов уведомление о событии изменения "MYItems" (см ниже).
В самом же классе наследованном EntitySet<Table> надо сделать wrapper (грубо говоря) над колекцией нечто вроде 
Код

public IBindingList MYItems
{
    get
    {
        return new BindingList<Table>(Children);
    }
}


наверно, как-то так....
вообще погуглите насчет linq2sql binding

Автор: coddy 9.4.2010, 07:59
Все оказалось намного проще - связывать нужно было через BindingSource:
Код

_bs = new BindingSource {DataSource = report.Table};
dgTable.DataSource = _bs;


Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)