DataGridView.ColumnHeaderMouseClick Olay

Tanım

Kullanıcı bir sütun üst bilgisine tıkladığında gerçekleşir.

C#
public event System.Windows.Forms.DataGridViewCellMouseEventHandler ColumnHeaderMouseClick;
C#
public event System.Windows.Forms.DataGridViewCellMouseEventHandler? ColumnHeaderMouseClick;

Olay Türü

Örnekler

içinde bir sütun başlığına tıklandığında DataGridView, varsayılan davranış kılavuz satırlarını tıklanan sütuna göre sıralamak veya kılavuz tıklanan sütuna göre zaten sıralanmışsa sıralama düzenini tersine çevirmektir. Aşağıdaki kod örneğinde, varsayılan davranış devre dışı bırakıldığında bir öğesine tıklamanın varsayılan davranışını öykünen programlı bir DataGridViewColumnHeaderCell sıralama gerçekleştirmek için bu olayın nasıl kullanılacağı gösterilmektedir. Bu örnekte , SelectionMode olarak ayarlanmıştır ColumnHeaderSelect, bu nedenle öğesine tıklandığında DataGridViewColumnHeaderCell sütunun içeriği seçilir. Örnek kodun amaçlandığı gibi çalışması için, veriler içine her yüklendiğinde varsayılan sütun başlığı tıklama davranışının DataGridViewdeğiştirilmesi gerekir. Varsayılan davranışı değiştiren kodu sağlamak için bir DataBindingComplete olay işleyicisi ekleyin. Bu örneği çalıştırmak için, kodu adlandırılmış dataGridView1 bir forma DataGridView yapıştırın ve tüm olayların olay işleyicileriyle ilişkilendirildiğinden emin olun.

C#
private void dataGridView1_ColumnHeaderMouseClick(
    object sender, DataGridViewCellMouseEventArgs e)
{
    DataGridViewColumn newColumn = dataGridView1.Columns[e.ColumnIndex];
    DataGridViewColumn oldColumn = dataGridView1.SortedColumn;
    ListSortDirection direction;

    // If oldColumn is null, then the DataGridView is not sorted.
    if (oldColumn != null)
    {
        // Sort the same column again, reversing the SortOrder.
        if (oldColumn == newColumn &&
            dataGridView1.SortOrder == SortOrder.Ascending)
        {
            direction = ListSortDirection.Descending;
        }
        else
        {
            // Sort a new column and remove the old SortGlyph.
            direction = ListSortDirection.Ascending;
            oldColumn.HeaderCell.SortGlyphDirection = SortOrder.None;
        }
    }
    else
    {
        direction = ListSortDirection.Ascending;
    }

    // Sort the selected column.
    dataGridView1.Sort(newColumn, direction);
    newColumn.HeaderCell.SortGlyphDirection =
        direction == ListSortDirection.Ascending ?
        SortOrder.Ascending : SortOrder.Descending;
}

private void dataGridView1_DataBindingComplete(object sender,
    DataGridViewBindingCompleteEventArgs e)
{
    // Put each of the columns into programmatic sort mode.
    foreach (DataGridViewColumn column in dataGridView1.Columns)
    {
        column.SortMode = DataGridViewColumnSortMode.Programmatic;
    }
}

Açıklamalar

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.