Dostat datagrid hodnoty po řadě index pro pozdější použití

0

Otázka

Snažím se získat hodnoty z buňky datagrid row jsem klikněte na, a uložit je pro pozdější použití, ale zdá se nemůžu dostat do práce.

Kliknutím na řádek by se zobrazí menu, na kterém si můžu dělat akce s těmito hodnotami.

To je to, co jsem dosáhl tak daleko

        private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs x)
        {
            if (dataGridView1.Rows[x.RowIndex].Cells["Name"].Value != null) name = dataGridView1.Rows[x.RowIndex].Cells["Name"].Value.ToString();
            else if (dataGridView1.Rows[x.RowIndex].Cells["LastName"].Value != null) last = dataGridView1.Rows[x.RowIndex].Cells["LastName"].Value.ToString();
        }

        private void dataGridView1_MouseDown(object sender, MouseEventArgs e)
        {
            if (e.Button == MouseButtons.Right)
            {
                if (last != null && name != null)
                {
                    ContextMenu cm = new ContextMenu();
                    this.ContextMenu = cm;
                    cm.MenuItems.Add(new MenuItem("&Do something with those values in this row", new System.EventHandler(this.do_Action_with_values)));
                    cm.Show(this, new Point(e.X, e.Y));
                }
                last = null;
                name = null;
            }
        }

Odstranění: if (konec != null && jméno != null)

Bude menu fungovat, ale hodnoty nejsou uloženy, všechny jsou null.

Je tam správně způsob, jak ukládat v řetězcích všechny hodnoty sloupců pro řádek klikli na?

c# datagrid
2021-11-23 17:36:12
1

Nejlepší odpověď

0

Na žádost v komentářích, použití CellMouseClick události a DataGridViewCellMouseEventArgs kombinovat své rutiny na jeden event handler, který má všechny vlastnosti, které potřebujete.

Kupující pozor, níže uvedený kód byl napsán mimo IDE, takže tam může být syntaxe/jiné chyby.

    private void dataGridView1_CellMouseClick(object sender, DataGridViewCellMouseEventArgs e)
    {
        if (e.Button != MouseButtons.Right) return;
        int row = e.RowIndex;
        string name = dataGridView1.Rows[row].Cells["Name"].Value;
        string last = dataGridView1.Rows[row].Cells["LastName"].Value;
        if (name == null || name.Trim().Length == 0) return;
        if (last == null || last.Trim().Length == 0) return;
        ContextMenu cm = new ContextMenu();
        this.ContextMenu = cm;
        cm.MenuItems.Add(new MenuItem("&Do something with those values in this row", new System.EventHandler(this.do_Action_with_values)));
        cm.Show(this, new Point(e.X, e.Y));
    }
2021-11-23 18:39:27

V jiných jazycích

Tato stránka je v jiných jazycích

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................