GridView的RowDataBound事件 獲取當前行的某個數據列


要獲取當前行的某個數據列,我在實踐中總結有如下幾種方法:

1. Cells[x].Txt。
    從列單元格的文本值獲取。這種方法簡單高率,最為常用,但是功能單純。此法存在幾個缺點:
    (1)無法獲取到設置了隱藏屬性的數據列的值,所取到的值為“”(空)。
    (2)只能獲取在HTML中定義過的數據列,無法查詢數據源中的當前數據行的所有字段列。一般情況下,通過HTML設置 GridView的字段列的數量往往小於數據源的實際字段數量,這是因為從業務邏輯的角度看,並不是所有的字段都是要顯示在頁面上的。當需要使用沒有被顯示的字段時,此法就不能直接滿足需求了。

2. e.Row.Cells[x].FindControl("YourcontrolName")。
    這是在單元格內查找某個服務器控件,從而獲得其數據值。這種方式可以操作單元格內的服務器控件。此法一般用於處理模板列中的數據或控件。

3. (DataRowView)e.Row.DataItem).Row.ItemArray[x].ToString()。
    此 法的核心是e.Row.DataItem,它是GridView的行數據集,為Object類型,將其轉化為DataRowView類型后,可以獲得更多 的操作方法。此數據集表示數據源當前行的全部字段列,ItemArray[x]是當前行全部字段列的數組對象,可以通過索引x獲得任意字段值。此法的強悍 之處是可以對數據源的全部字段查詢。

4. DataBinder.Eval(e.Row.DataItem, "YourDataFieldName").ToString()。
    此法仍然
基於e.Row.DataItem,其特點是更快捷的獲得數據源的任意字段值,因為使用了DataBinder.Eval(),需要注意的是不要寫錯字段名稱。

5. 將e.Row.DataItem轉化為自定義類型,實現數據類型化。
    例如:
    DSRequestTracking.TB_RequestTrackingRow rtrow=(DSRequestTracking.TB_RequestTrackingRow)((DataRowView)e.Row.DataItem).Row;
    RequestStatusDropDownList1.SelectedValue = rtrow.StatusID.ToString();
    其中DSRequestTracking是通過DSRequestTracking.xsd文 件在工程中自定義的強類型DataSet, TB_RequestTrackingRow是VS自動為此強類型生成的創建數據行對象的方法。通過此法,實現了類型化數據的廣泛應用。數據類型化的好處 很多,顯而易見的便是傳一個類型數據給方法,取代一大堆參數,另外就是再也不會發生字段名拼寫錯誤的情況。


免責聲明!

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



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