DataGridView.RowContextMenuStripNeeded Olay

Tanım

Satırın kısayol menüsü gerektiğinde gerçekleşir.

C#
public event System.Windows.Forms.DataGridViewRowContextMenuStripNeededEventHandler RowContextMenuStripNeeded;
C#
public event System.Windows.Forms.DataGridViewRowContextMenuStripNeededEventHandler? RowContextMenuStripNeeded;

Olay Türü

Örnekler

Aşağıdaki kod örneği, çalışanın RowContextMenuStripNeeded unvanını temel alan bir ContextMenuStrip sağlamak için olayı işler. Bu örnekte, biri yöneticiler ve diğeri diğer tüm çalışanlar için iki kısayol menüsü vardır.

C#
void dataGridView1_RowContextMenuStripNeeded(object sender,
    DataGridViewRowContextMenuStripNeededEventArgs e)
{
    DataGridViewRow dataGridViewRow1 = dataGridView1.Rows[e.RowIndex];

    toolStripMenuItem1.Enabled = true;

    // Show the appropriate ContextMenuStrip based on the employees title.
    if ((dataGridViewRow1.Cells["Title"].Value.ToString() ==
        "Sales Manager") ||
        (dataGridViewRow1.Cells["Title"].Value.ToString() ==
        "Vice President, Sales"))
    {
        e.ContextMenuStrip = managerMenuStrip;
    }
    else
    {
        e.ContextMenuStrip = employeeMenuStrip;
    }

    contextMenuRowIndex = e.RowIndex;
}

Açıklamalar

Olay RowContextMenuStripNeeded yalnızca DataGridView denetim DataSource özelliği ayarlandığında veya VirtualMode özelliği olduğunda truegerçekleşir. Bir satırın RowContextMenuStripNeeded geçerli durumuna veya içerdiği değerlere göre belirlenen bir kısayol menüsü görüntülemek istediğinizde olayı işleme yararlı olur.

Olayı işlediğinizde RowContextMenuStripNeeded , kullanıcı tıklanan hücrenin kısayol menüsünü geçersiz kılmadığı sürece, kullanıcı bir satıra sağ tıkladığında CellContextMenuStripNeeded işleyicide belirttiğiniz kısayol menüsü gösterilir.

Olay RowContextMenuStripNeeded ayrıca, özelliğin DataGridViewRow.ContextMenuStrip değeri program aracılığıyla veya kullanıcı bir satıra sağ tıkladığında da gerçekleşir.

bir satırın DataGridViewRowContextMenuStripNeededEventArgs.RowIndex veya içerdiği değerlerin durumunu belirlemek için özelliğini kullanabilir ve bu bilgileri özelliği değiştirmek veya değiştirmek için kullanabilirsiniz DataGridViewRowContextMenuStripNeededEventArgs.ContextMenuStrip . Bu özellik, olay değerinin geçersiz kıldığı satır ContextMenuStrip özelliğinin değeriyle başlatılır.

RowContextMenuStripNeeded Birden çok satır için satır ContextMenuStrip değerini ayarlamanın performans cezalarını önlemek için büyük miktarda veriyle çalışırken olayı işleyebilir. Daha fazla bilgi için bkz. Windows Forms DataGridView Denetimini Ölçeklendirmeye Yönelik En İyi Yöntemler.

Olayları işleme hakkında daha fazla bilgi için bkz. Olayları İşleme ve Oluşturma.

Şunlara uygulanır

Ürün Sürümler
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10

Ayrıca bkz.