dataGridView1 подключиться к моему общему списку? - PullRequest
3 голосов
/ 05 февраля 2011

dataGridView1 Я хочу подключиться к моему общему списку.Для этого я использую код ниже.

dataGridView1.DataSource = List;

(список статический)

Но каждый раз, когда я хочу обновить список, общие данные dataGridView1 также получают обновление.

1 Ответ

2 голосов
/ 05 февраля 2011

Используйте BindingList<T> вместо;это обеспечивает уведомления об изменении крышки (добавить, удалить и т. д.).Он также предоставляет уведомления на уровне строк (для изменений свойств), но только если ваш тип правильно реализует INotifyPropertyChanged;поэтому реализуйте это.

Если ваш «список статичен», если вы имеете в виду поле static, обратите внимание, что если это так.Используя несколько потоков, вы можете столкнуться с проблемами;Лично я бы так не поступил, но это не имеет отношения к вопросу.

Пример:

using System;
using System.ComponentModel;
using System.Windows.Forms;

static class Program
{
    class Foo
    {
        public int A { get; set; }
        public string B { get; set; }
    }
    [STAThread]
    static void Main()
    {
        Application.EnableVisualStyles();
        Application.SetCompatibleTextRenderingDefault(false);
        using (var form = new Form())
        using (var grid = new DataGridView { Dock = DockStyle.Fill })
        using (var add = new Button { Dock = DockStyle.Bottom, Text = "add" })
        using (var remove = new Button { Dock = DockStyle.Top, Text = "remove" })
        {
            form.Controls.Add(grid);
            form.Controls.Add(add);
            form.Controls.Add(remove);
            var lst = new BindingList<Foo>();
            var rnd = new Random();
            add.Click += delegate
            {
                lst.Add(new Foo { A = rnd.Next(1, 6), B = "new" });
            };
            remove.Click += delegate
            {
                int index = 0;
                foreach (var row in lst)
                { // just to illustrate removing a row by predicate
                    if (row.A == 2) { lst.RemoveAt(index); break; }
                    index++;
                }
            };
            grid.DataSource = lst;
            Application.Run(form);
        }
    }
}
...