zoukankan      html  css  js  c++  java
  • GridView 中的单元格值

    一般要取得 GridView 中的单元格值,都是要指定该单元格所在的行列索引,根据单元格在浏览或编辑模式下,需要使用不同的方式来获取。

    例如有一个“地区”的 BoundField,它是 GridView 中的第3列,在浏览模式下取得“地区”列的值,如下:

    GridViewRow.Cells(3).Text

    如果是在编辑模式时,因为该列值是在 Cell 中的 TextBox中,所以要使用下列方式来提取编辑时“地区”列的值,如下:

    CType(oRow.Cells(3).Controls(0), TextBox).Text

    以上获取 GridView 单元格值的没有良好的通用性,只要改变列顺序或变更列的类型(例如变成 TemplateField),这样程序很容易就发生错误,如果有变化则程序也需要随时修改。

    为了在实际应用中解决这个问题,经过几种方式的对比,感觉比较好的方式是以列名来提取值。DataControlField 有一个 ExtractValuesFromCell 方法,不论是浏览或编辑模式都可以简单的取出 Cell 的对应的列,也不用去管它使用那一种 DataControlField (BoundField 、 CheckBoxField 或 TemplateField ) 都可以正确的取得对应的单元格值。

    下面的程序示例就是通过 ExtractRowValues 函数获取出 GridView 指定单元格的值。
    C#.NET:
    程序代码 程序代码
    private orderedDictionary ExtractRowValues(DataControlFieldCollection Columns, GridViewRow Row)
        {
            orderedDictionary oFieldValues;
            orderedDictionary oDictionary;
            DataControlField oColumn;
            
            oFieldValues = new orderedDictionary(Columns.Count);
            oDictionary = new orderedDictionary();

            for (int i = 0; i < Columns.Count; i++)
            {
                oColumn = Columns[i];
                if (oColumn.Visible)
                {
                    oDictionary.Clear();
                    oColumn.ExtractValuesFromCell(oDictionary, (DataControlFieldCell)Row.Cells[i], Row.RowState, true);
                    foreach (DictionaryEntry oEntry in oDictionary)
                    {
                        oFieldValues.Add(oEntry.Key, oEntry.Value);
                    }
                }
            }

            return oFieldValues;
        }
        
        protected void Button1_Click(Object sender, EventArgs e)
        {
            GridViewRow orow;
            System.Collections.Specialized.OrderedDictionary oFieldValues;
            orow = (GridViewRow)GridView1.Rows[1];
            oFieldValues = ExtractRowValues(GridView1.Columns, orow);

            //输出 “地区”名
            this.Response.Write(oFieldValues["地区"].ToString());
        }
     
  • 相关阅读:
    LeetCode 295. Find Median from Data Stream (堆)
    LeetCode 292. Nim Game(博弈论)
    《JavaScript 模式》读书笔记(4)— 函数2
    《JavaScript 模式》读书笔记(4)— 函数1
    《JavaScript 模式》读书笔记(3)— 字面量和构造函数3
    《JavaScript 模式》读书笔记(3)— 字面量和构造函数2
    《JavaScript 模式》读书笔记(3)— 字面量和构造函数1
    《JavaScript 模式》读书笔记(2)— 基本技巧3
    《JavaScript 模式》读书笔记(2)— 基本技巧2
    《JavaScript 模式》读书笔记(2)— 基本技巧1
  • 原文地址:https://www.cnblogs.com/zyizyizyi/p/2497840.html
Copyright © 2011-2022 走看看