Графический элемент управления C# для редактирования словаря



Существует ли стандартный элемент управления, позволяющий пользователю редактировать пары ключ-значение словаря строк?



Если нет, то как бы вы его реализовали? У меня есть несколько идей, но ни одна из них не кажется отличной.

616   2  

2 ответов:

Нет, там нет ни одного встроенного. Для реализации одного; как насчет 2-столбца DataGridView, реализующего IDataErrorInfo таким образом, что дублированные ключи приводят к красному blob-объекту ошибки:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Windows.Forms;
class Pair : IDataErrorInfo
{
    internal IList<Pair> Parent { get; set; }
    public string Key { get; set; }
    public string Value { get; set; }

    string IDataErrorInfo.Error
    {
        get { return ""; }
    }

    string IDataErrorInfo.this[string columnName]
    {
        get
        {   
            if(columnName == "Key" && Parent != null && Parent.Any(
                x=> x.Key == this.Key && !ReferenceEquals(x,this)))
            {
                return "duplicate key";
            }
            return "";        
        }
    }
}

static class Program
{
    [STAThread]
    static void Main()
    {
        Application.EnableVisualStyles();
        BindingList<Pair> pairs = new BindingList<Pair>();
        // todo: fill from StringDictionary
        pairs.AddingNew += (s,a) =>
        {
            a.NewObject = new Pair { Parent = pairs };
        };
        Application.Run(new Form {
            Controls = {new DataGridView {
                Dock = DockStyle.Fill,
                DataSource = pairs
            }}
        });
    }
}

Просто составить список и привязки их к сетке. Быстро и легко.

EDIT: вот пример, предположим, что у вас есть форма с GridView на ней.

Dictionary<string, string> d;
protected void Page_Load(object sender, EventArgs e)
{
d = new Dictionary<string, string>();
d.Add("key 1", 1);
d.Add("key 2", 2);
d.Add("key 3", 3);
d.Add("key 4", 4);
d.Add("key 5", 5);

GridView1.DataSource = d;
GridView1.DataBind();

}

Для обработки ошибок и т. д. Проверьте ответ Марка. Возможно, вы также захотите провести дополнительные исследования по привязке данных.

Comments

    Ничего не найдено.