DataGridView使用技巧十三:點擊列頭實現升序和降序排序


DataGridView 列有三種排序模式。每一列的排序模式是通過該列的 SortMode 屬性指定的,該屬性可以設置為以下的 DataGridViewColumnSortMode 枚舉值之一。

DataGridViewColumnSortMode 值說明:

Automatic
文本框列的默認排序模式。除非將列標頭用於選擇,否則單擊列標頭將自動按此列對 DataGridView 排序,並顯示一個指示排序順序的標志符號(向上的三角箭頭:升序排序;向下的三角箭頭:降序排序)。

NotSortable
非文本框列的默認排序模式。可以以編程方式對此列排序;但此列不適合排序,因此未為排序標志符號保留空間。

Programmatic
可以以編程方式對此列排序;而且為排序標志符號保留了空間。

一、使用SortMode屬性自動排序

1、通過程序設置

private void FrmMain_Load(object sender, EventArgs e)
{
     foreach (DataGridViewColumn column in this.dgv_Users.Columns)
    {
          //設置自動排序
          column.SortMode = DataGridViewColumnSortMode.Automatic;
    }
}

2、在設計界面修改屬性

二、使用編程的方式實現自定義排序

可以以編程方式按任一列或多列中的值對 DataGridView 排序,而不論 SortMode 設置如何。當希望為排序提供自己的用戶界面 (UI) 時,或者當希望實現自定義排序時,以編程方式排序很有用。提供自己的排序用戶界面非常有用,例如,在設置 DataGridView 選擇模 式以啟用列標頭選擇時。在這種情況下,雖然列標頭不能用於排序,但是仍希望標頭顯示相應的排序標志符號,因此將 SortMode 屬性設置為 Programmatic。

設置為編程排序模式的列不會自動顯示排序標志符號。對於這些列,必須通過設置 System.Windows.Forms.DataGridViewColumnHeaderCell.SortGlyphDirection 屬性 來手動顯示標志符號。為了在自定義排序中能夠靈活操作,這是必需的。例如,如果按多列對 DataGridView 排序,則可能希望顯示多個排序標志符 號或不顯示任何標志符號。

對於已排序的 DataGridView,可以通過檢查 SortedColumn 和 SortOrder 屬性的值確定排序列和排序順序。

如果SortMode的屬性設置為Programmatic就需要使用編程的方式在ColumnHeaderMouseClick事件中實現自定義排序。

示例:

 1 private void dgv_Users_ColumnHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
 2 {          
 4      DataGridView dgv = sender as DataGridView;
 5      if (dgv.Columns[e.ColumnIndex].SortMode == DataGridViewColumnSortMode.Programmatic)
 6      {
 7          string columnBindingName = dgv.Columns[e.ColumnIndex].DataPropertyName;
 8          switch (dgv.Columns[e.ColumnIndex].HeaderCell.SortGlyphDirection)
 9          {
10             case System.Windows.Forms.SortOrder.None:
11             case System.Windows.Forms.SortOrder.Ascending:
12                    CustomSort(columnBindingName, "desc");
13                    dgv.Columns[e.ColumnIndex].HeaderCell.SortGlyphDirection = System.Windows.Forms.SortOrder.Descending;
14                    break;
15             case System.Windows.Forms.SortOrder.Descending:
16                    CustomSort(columnBindingName, "asc");
17                    dgv.Columns[e.ColumnIndex].HeaderCell.SortGlyphDirection = System.Windows.Forms.SortOrder.Ascending;
18                    break;
19             }
20        }          
21 }
22 
23 /// <summary>
24 /// 自定義排序
25 /// </summary>
26 /// <param name="columnName">綁定的字段名</param>
27 /// <param name="sortMode">排序方式 asc 升序 desc 降序</param>
28 private void CustomSort(string columnBindingName, string sortMode)
29 {
30       DataTable dt = this.dgv_Users.DataSource as DataTable;
31       DataView dv = dt.DefaultView;
32       dv.Sort = columnBindingName + " " + sortMode;
33       this.dgv_Users.DataSource = dv.ToTable();
34       this.dgv_Users.Refresh();
35 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM