С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Автор FAQ
Автор FAQ
 Аватар для REALIST07
644 / 199 / 21
Регистрация: 11.06.2010
Сообщений: 1,024

Подружить DataGridView c BindingList

16.01.2019, 12:44. Показов 2623. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть форма с гридом и соответствующие модели для них,после добавления не отображаются добавленные поля(см. скрин)
Подключается вот так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public BindingList<CustomerViewModel> CustomerList
        {
            get { return _customerList;}
            set
            {
                Clients.DataSource = value; //new BindingSource(value,null); - так тоже пробовал
                _customerList = value;
                resizeGrid(Clients);
            }
        }
        ...
        private void resizeGrid(DataGridView grid)
        {
            grid.AutoResizeColumns();
            grid.AutoResizeRows();
        }
Я подумал, что так как поля у меня фиксированные в гриде,а полей у модели больше,то можно сделать BindingList<object[]> для каждого поля, написал такой метод:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
public static BindingList<object[]> ToObjectsBindingList<T>(BindingList<T> models,IEnumConvertor convertor) where T : BaseViewModel
        {
            BindingList<object[]> result = new BindingList<object[]>();
            foreach (var model in models)
            {
                result.Add(model.ToTableRow(convertor));
            }
 
            return result;
        }
// базовый класс
public abstract class BaseViewModel
    {
        public bool IsModelEmpty { get; set; }
        public abstract object[] ToTableRow(IEnumConvertor enumConvertor);
    }
 
// вот и сама модель
public class CustomerViewModel : BaseViewModel
    {
        public CustomerViewModel()
        {
            Id = Guid.NewGuid();
            IsModelEmpty = true;
        }
     
        
 
        public string[] GetEditItems()
        {
            return new string[]
            {
                Inn,
                Name,
                ContactEmail,
                SpecialEmail,
                Address,
                LegalAddress,
                Phone1,
                Phone2,
                Country,
                Region,
                City
            
            };
        }
 
        public void Update(CustomerViewModel update)
        {
            Inn = update.Inn;
            Name = update.Name;
            ContactEmail = update.ContactEmail;
            SpecialEmail = update.SpecialEmail;
            Address = update.Address;
            LegalAddress = update.LegalAddress;
            Phone1 = update.Phone1;
            Phone2 = update.Phone2;
            Country = update.Country;
            Region = update.Region;
            City = update.City;
            Condition = update.Condition;
            AllPrice = update.AllPrice;
            AllPay = update.AllPay;
        }
 
        public override bool Equals(object obj)
        {
            CustomerViewModel other =  obj as CustomerViewModel;
            if (other == null) return false;
            for (int i = 0; i < this.GetEditItems().Length; i++)
            {
                var thisItem = this.GetEditItems()[i];
                var otherItem = other.GetEditItems()[i];
 
                if (this.Condition != other.Condition) return false;
                if (string.IsNullOrEmpty(thisItem) && !string.IsNullOrEmpty(otherItem)) return false;
                if (!string.IsNullOrEmpty(thisItem) && string.IsNullOrEmpty(otherItem)) return false;
                if (string.Compare(thisItem, otherItem, StringComparison.Ordinal) != 0) return false;
 
            }
 
            if (!decimal.Equals(this.AllPay, other.AllPay) ||
                !decimal.Equals(this.AllPrice, other.AllPrice))
                return false;
 
            return true;
        }
 
        public override int GetHashCode()
        {
            return Id.GetHashCode();
        }
 
        
 
 
        public Guid Id { get; set; }
        public string ModuleId { get; set; }
 
        public string Inn { get; set; }
        public string Name { get; set; }
        public string ContactEmail { get; set; }
        public string SpecialEmail { get; set; }
        public string Address { get; set; }
        public string LegalAddress { get; set; }
        public string Phone1 { get; set; }
        public string Phone2 { get; set; }
        public string Country { get; set; }
        public string Region { get; set; }
        public string City { get; set; }
 
        public Conditions Condition { get; set; }
 
        public decimal DebetBegin { get; set; }
        public decimal CreditBegin { get; set; }
        public decimal DebetEnd { get; set; }
        public decimal CreditEnd { get; set; }
        public decimal AllPrice { get; set; }
        public decimal AllPay { get; set; }
 
        public bool IsMine { get; set; }
 
        public long LastUpdateDate { get; set; }
 
        public virtual List<OrderViewModel> Orders { get; set; }
        public virtual List<MessageViewModel> Messages { get; set; }
 
 
        //вот метод, который выдает нужные поля
        public override object[] ToTableRow(IEnumConvertor enumConvertor)
        {
            return new object[] {
                Id, Inn, Country, Region, City, Name, DebetBegin,
                CreditBegin, DebetEnd, CreditEnd, AllPrice, AllPay,
                Address, enumConvertor.ToDescriptionString(Condition), Phone1, ContactEmail, LegalAddress,
                Phone2, SpecialEmail, ModuleId, IsMine, LastUpdateDate };
        }
    }
В конечном итоге не получилось ни напрямую подключить,ни с помощью преобразования в список объектов, подскажите, что я делаю не так?
Миниатюры
Подружить DataGridView c BindingList  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.01.2019, 12:44
Ответы с готовыми решениями:

Как связать DataGridView и BindingList<object[]>?
Всем привет. Прошу сильно не пинать за 100500-й банальный вопрос, но я сегодня просидел полдня и так не смог осилить, перечитал и форум и...

Как подружить bindingSource, bindingNavigator и два DataGridView
С помощью bindingSource, я фильтрую основную таблицу, bindingNavigator сами знаете зачем нужен, в два DataGridView выводятся связанные...

Привязка BindingList к DataGridView и поведение CurrentCell
Натолкнулся на интересное поведение DataGridView. (1) Если к нему привязать некий BindingList: dgv.DataSource=bindlist1 и походить...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.01.2019, 12:44
Помогаю со студенческими работами здесь

DataGridViev BindingList
Здравствуйте! в очередной раз обращаюсь к вам! Проблема такая есть DataGridview. Через DataSource я указываю источник данных...

Изменение строки в BindingList
Как можно изменить значение необходимой строки в BindingList? добавление и удаление ниже, а с изменением тяжко BindingList&lt;User&gt;...

DataGridViev = BindingList<MyClass>
Доброго дня всем! dataGridViev = BindingList&lt;MyClass&gt; появляются пустые строки! какой метод должен быть реализован в MyClass что бы...

Сортировка BindingList<MyClass>
Как отсортировать этот список без переписываний туда-сюда по 10 раз? IEnumerable&lt;D1&gt; Query; BindingList&lt;D1&gt; Tmp = new...

Извлечение объекта из BindingList<>
Прошу подсказать каким образом могу извлечь необходимый объект по индексу из BindingList&lt;&gt; Program.cs static class Program ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru