轉(zhuǎn)帖|其它|編輯:郝浩|2011-08-05 11:19:49.000|閱讀 1585 次
概述:我們見過Excel中的數(shù)據(jù)過濾功能,可以通過點擊表頭上的下拉列表來實現(xiàn)數(shù)據(jù)的過濾,這個功能很實用,省去了我們需要在程序中單獨設(shè)計數(shù)據(jù)的查詢過濾模塊,功能直接依賴于數(shù)據(jù)綁定控件DataGridView。先來看看Excel中的數(shù)據(jù)過濾功能。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
我們見過Excel中的數(shù)據(jù)過濾功能,可以通過點擊表頭上的下拉列表來實現(xiàn)數(shù)據(jù)的過濾,這個功能很實用,省去了我們需要在程序中單獨設(shè)計數(shù)據(jù)的查詢過濾模塊,功能直接依賴于數(shù)據(jù)綁定控件DataGridView。先來看看Excel中的數(shù)據(jù)過濾功能。
要想在DataGridView中實現(xiàn)類似于Excel的這種功能其實也并非難事。來看看msdn上的一篇文章,上面有詳細(xì)的介紹,不過目前只有全英文的版本。。里面提供的下載示例我這里也可以提供一份:
文章講了很多有關(guān)如何實現(xiàn)數(shù)據(jù)過濾的知識,如果你有耐心可以通讀一遍,應(yīng)該能有不小的收獲。其實這里面的原理就是我 們需要自定義一種DataGridViewColumn,它能支持用戶通過點擊表頭上的下拉列表來實現(xiàn)DataGridView的數(shù)據(jù)過濾。自定義的 DataGridViewColumn可以繼承自現(xiàn)有的DataGridViewTextBoxColumn類型,另外還需要自定義一個繼承自 DataGridViewColumnHeaderCell的類型,它負(fù)責(zé)在DataGridView表頭上呈現(xiàn)一個下拉列表,并完成數(shù)據(jù)過濾的選擇功 能。下載上面的DataGridViewAutoFilter.zip壓縮包,將里面對應(yīng)編程語言中的 DataGridViewAutoFilterColumnHeaderCell.cs和 DataGridAutoFilterTextBoxColumn.cs兩個文件加入到你的工程中。然后需要重新定義DataGridView中的列,如 果你是手動指定DataGridView的列,則需要在窗體的Designer.cs文件中手動修改與DataGridView列相關(guān)的代碼;或者你也可 以通過程序動態(tài)指定DataGridView的列。將需要顯示數(shù)據(jù)過濾的列的類型指定為 DataGridViewAutoFilterTextBoxColumn類型。另外在綁定DataGridView數(shù)據(jù)源時必須使用 BindingSource而不能使用如DataTable之類的普通數(shù)據(jù)源,這一點非常重要!在后面的代碼展示中你將會看到為什么要這么做。
這里是具體的例子:
代碼中的第16行將LINQ的查詢結(jié)果轉(zhuǎn)換成了DataTable對象,相關(guān)內(nèi)容大家可以看我的另一篇文章“”。 另外代碼中將DataGridView的所有列的類型指定成了DataGridViewAutoFilterTextBoxColumn,使其能夠支持自 定義的數(shù)據(jù)過濾功能。好了,現(xiàn)在運行你的應(yīng)用程序,將會看到表頭上有下拉列表的小箭頭,點擊它并選擇下拉列表中的項便可實現(xiàn)DataGridView數(shù)據(jù) 的排序。是不是很酷???不過這里還有一個小問題,那就是用戶如何知道我當(dāng)前選擇了哪個列的數(shù)據(jù)過濾,界面是不是應(yīng)該給出相應(yīng)的數(shù)據(jù)過濾信息呢?我們可以在 窗體的StatusStrip控件中添加一些Label標(biāo)簽用來顯示這些信息:
1. 顯示用戶當(dāng)前選擇了多少行。這個需要將DataGridView的SelectionMode屬性設(shè)置成行選擇模式即FullRowSelect。
2. 顯示當(dāng)前DataGridView一共有多少行。
3. 顯示Filter的信息及應(yīng)用數(shù)據(jù)過濾之后的總行數(shù)。
4. 添加一個按鈕或鏈接用于移除當(dāng)前的Filter。
來看看具體的實現(xiàn)代碼及程序運行時的效果:
1. 當(dāng)前用戶選擇的總行數(shù)。
2. DataGridView中一共有多少行。
3. Filter的信息及使用Filter之后的數(shù)據(jù)行數(shù)。
4. 用于移除Filter的鏈接。
代碼中一個是三個事件,dataGridView1_SelectionChanged事件用于在 DataGridView行被選擇時觸發(fā),用來更新StatusStrip中當(dāng)前用戶選擇的總行 數(shù);dataGridView1_DataBindingComplete事件在DataGridView數(shù)據(jù)完成綁定時觸發(fā),用來更新 StatusStrip中Filter的信息及使用Filter之后的數(shù)據(jù)行數(shù),以及DataGridView的數(shù)據(jù)總行數(shù),注意其中將 BindingSource的RaiseListChangedEvents設(shè)置為false以取得DataGridView數(shù)據(jù)源中的真實數(shù)據(jù)行數(shù),之 后再將其設(shè)置為true以獲取到Filter的相關(guān)信息;toolStripStatus_ShowAll_Click事件為用戶點擊Show All鏈接時觸發(fā),用于移除DataGridView中的Filter。
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@ke049m.cn
文章轉(zhuǎn)載自:博客園