Привязка DataGridView - PullRequest
       4

Привязка DataGridView

2 голосов
/ 11 марта 2009

У меня есть gridview, к которому я привязываюсь через общий список. Я сам установил все столбцы. Я просто пытаюсь:

Перехватить ошибку формата события PRE при редактировании строки - получить информацию о строке через скрытое поле - и сохранить

Я уверен, что это должно быть довольно легко, но я мало что сделал с работой с формами, и я незнаком с ее событиями DataGridViews.

1 Ответ

6 голосов
/ 11 марта 2009

Есть два способа посмотреть на это;

  • обрабатывает событие CellParsing и анализирует значение
  • использовать пользовательский TypeConverter на имущество

Я обычно предпочитаю последнее, так как оно убирает эту логику из пользовательского интерфейса; Я посмотрю, смогу ли я сделать пример ...


Пример (большая часть этого кода - это код "покажи это работает"); здесь я определяю MyDateTimeConverter, который форматирует / анализирует даты как их назад текст "dd MMM гггг" (без веской причины), и связываю этот конвертер с одним из свойств. Вы можете отредактировать значения в сетке, и изменения будут перенесены обратно (измените строки, чтобы увидеть «актуальное» обновление значения). Это не показывается сразу из-за некоторых нюансов вокруг уведомления об изменении; не стоило делать пример более сложным только для этого ...

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Globalization;
using System.Windows.Forms;

class Person
{
    public string Forename { get; set; }
    public string Surname { get; set; }

    [TypeConverter(typeof(MyDateTimeConverter))]
    public DateTime EditableValue { get { return ActualValue; } set { ActualValue = value; } }
    // this just proves what we have set...
    public DateTime ActualValue { get; private set; }
}
class MyDateTimeConverter : TypeConverter
{
    public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType)
    {
        return sourceType == typeof(string) || base.CanConvertFrom(context, sourceType);
    }
    public override bool CanConvertTo(ITypeDescriptorContext context, Type destinationType)
    {
        return destinationType == typeof(string) || base.CanConvertTo(context, destinationType);
    }
    const string FORMAT = "dd MMM yyyy";
    public override object ConvertFrom(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value)
    {
        if (value != null && value is string)
        {
            string s = (string)value;
            return DateTime.ParseExact(Reverse(s), FORMAT, CultureInfo.InvariantCulture);
        }
        return base.ConvertFrom(context, culture, value);
    }
    public override object ConvertTo(ITypeDescriptorContext context, CultureInfo culture, object value, Type destinationType)
    {
        if (destinationType == typeof(string))
        {
            return Reverse(((DateTime)value).ToString(FORMAT, CultureInfo.InvariantCulture));
        }
        return base.ConvertTo(context, culture, value, destinationType);
    }
    static string Reverse(string value)
    {
        char[] data = value.ToCharArray();
        Array.Reverse(data);
        return new string(data);
    }
}
class MyForm : Form
{
    public MyForm()
    {
        DataGridView grid = new DataGridView();
        grid.Dock = DockStyle.Fill;
        List<Person> people = new List<Person>();
        people.Add(new Person { Forename = "Fred", Surname = "Flintstone", EditableValue = DateTime.Today });
        people.Add(new Person { Forename = "Barney", Surname = "Rubble", EditableValue = DateTime.Today.AddDays(-25) });
        grid.DataSource = people;
        Controls.Add(grid);
    }
    static void Main()
    {
        Application.EnableVisualStyles();
        Application.Run(new MyForm());
    }
}
...