Модераторы: gambit, Partizan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Обновление записей dataGridView, При обновлении связанного объекта linq 
:(
    Опции темы
coddy
Дата 8.4.2010, 09:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 10.10.2009

Репутация: нет
Всего: нет



Добрый день!
имеется 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();

Безуспешно.

Как заставить грид автоматически добавлять новые строки, при добавлении объектов в коллекцию?
PM MAIL ICQ Jabber   Вверх
jonie
Дата 8.4.2010, 09:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 5613
Регистрация: 21.8.2005
Где: Владимир

Репутация: 5
Всего: 118



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

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


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


--------------------
Что-то не поняли? -> Напейтесь до зеленых человечков... эта сверхцивилизация Вам поможет...
PM MAIL Jabber   Вверх
coddy
Дата 9.4.2010, 07:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 10.10.2009

Репутация: нет
Всего: нет



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

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



Это сообщение отредактировал(а) coddy - 9.4.2010, 08:00
PM MAIL ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Прежде чем создать тему, посмотрите сюда:
mr.DUDA
THandle

Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов.
Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :)
Так же не забывайте отмечать свой вопрос решенным, если он таковым является :)


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, THandle.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Разработка Windows Forms | Следующая тема »


 




[ Время генерации скрипта: 0.0666 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.